forked from TrueCloudLab/rclone
lsjson,lsf: make sure metadata appears for directories
This commit is contained in:
parent
e4d0055b3e
commit
09953d77b5
2 changed files with 22 additions and 9 deletions
|
@ -194,6 +194,14 @@ func (lj *listJSON) entry(ctx context.Context, entry fs.DirEntry) (*ListJSONItem
|
||||||
}
|
}
|
||||||
item.Encrypted = path.Base(item.EncryptedPath)
|
item.Encrypted = path.Base(item.EncryptedPath)
|
||||||
}
|
}
|
||||||
|
if lj.opt.Metadata {
|
||||||
|
metadata, err := fs.GetMetadata(ctx, entry)
|
||||||
|
if err != nil {
|
||||||
|
fs.Errorf(entry, "Failed to read metadata: %v", err)
|
||||||
|
} else if metadata != nil {
|
||||||
|
item.Metadata = metadata
|
||||||
|
}
|
||||||
|
}
|
||||||
if do, ok := entry.(fs.IDer); ok {
|
if do, ok := entry.(fs.IDer); ok {
|
||||||
item.ID = do.ID()
|
item.ID = do.ID()
|
||||||
}
|
}
|
||||||
|
@ -224,14 +232,6 @@ func (lj *listJSON) entry(ctx context.Context, entry fs.DirEntry) (*ListJSONItem
|
||||||
item.Tier = do.GetTier()
|
item.Tier = do.GetTier()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if lj.opt.Metadata {
|
|
||||||
metadata, err := fs.GetMetadata(ctx, x)
|
|
||||||
if err != nil {
|
|
||||||
fs.Errorf(x, "Failed to read metadata: %v", err)
|
|
||||||
} else if metadata != nil {
|
|
||||||
item.Metadata = metadata
|
|
||||||
}
|
|
||||||
}
|
|
||||||
default:
|
default:
|
||||||
fs.Errorf(nil, "Unknown type %T in listing in ListJSON", entry)
|
fs.Errorf(nil, "Unknown type %T in listing in ListJSON", entry)
|
||||||
}
|
}
|
||||||
|
|
|
@ -174,7 +174,7 @@ func TestListJSON(t *testing.T) {
|
||||||
}, {
|
}, {
|
||||||
name: "Metadata",
|
name: "Metadata",
|
||||||
opt: operations.ListJSONOpt{
|
opt: operations.ListJSONOpt{
|
||||||
FilesOnly: true,
|
FilesOnly: false,
|
||||||
Metadata: true,
|
Metadata: true,
|
||||||
},
|
},
|
||||||
want: []*operations.ListJSONItem{{
|
want: []*operations.ListJSONItem{{
|
||||||
|
@ -183,6 +183,10 @@ func TestListJSON(t *testing.T) {
|
||||||
Size: 5,
|
Size: 5,
|
||||||
ModTime: operations.Timestamp{When: t1},
|
ModTime: operations.Timestamp{When: t1},
|
||||||
IsDir: false,
|
IsDir: false,
|
||||||
|
}, {
|
||||||
|
Path: "sub",
|
||||||
|
Name: "sub",
|
||||||
|
IsDir: true,
|
||||||
}},
|
}},
|
||||||
},
|
},
|
||||||
} {
|
} {
|
||||||
|
@ -203,6 +207,15 @@ func TestListJSON(t *testing.T) {
|
||||||
} else {
|
} else {
|
||||||
assert.NotEqual(t, "", got[i].MimeType)
|
assert.NotEqual(t, "", got[i].MimeType)
|
||||||
}
|
}
|
||||||
|
if test.opt.Metadata {
|
||||||
|
features := r.Fremote.Features()
|
||||||
|
if features.ReadMetadata && !got[i].IsDir {
|
||||||
|
assert.Greater(t, len(got[i].Metadata), 0, "Expecting metadata for file")
|
||||||
|
}
|
||||||
|
if features.ReadDirMetadata && got[i].IsDir {
|
||||||
|
assert.Greater(t, len(got[i].Metadata), 0, "Expecting metadata for dir")
|
||||||
|
}
|
||||||
|
}
|
||||||
if test.opt.ShowHash {
|
if test.opt.ShowHash {
|
||||||
hashes := got[i].Hashes
|
hashes := got[i].Hashes
|
||||||
assert.NotNil(t, hashes)
|
assert.NotNil(t, hashes)
|
||||||
|
|
Loading…
Reference in a new issue