You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
650 lines
25 KiB
650 lines
25 KiB
import 'dart:convert'; |
|
import 'dart:math'; |
|
import 'dart:typed_data'; |
|
|
|
import 'package:nextcloud/nextcloud.dart'; |
|
import 'package:nextcloud_test/nextcloud_test.dart'; |
|
import 'package:test/test.dart'; |
|
import 'package:universal_io/io.dart'; |
|
|
|
void main() { |
|
group('constructUri', () { |
|
for (final values in [ |
|
('http://cloud.example.com', 'http://cloud.example.com'), |
|
('http://cloud.example.com/', 'http://cloud.example.com'), |
|
('http://cloud.example.com/subdir', 'http://cloud.example.com/subdir'), |
|
('http://cloud.example.com/subdir/', 'http://cloud.example.com/subdir'), |
|
]) { |
|
final baseURL = Uri.parse(values.$1); |
|
final sanitizedBaseURL = Uri.parse(values.$2); |
|
|
|
test(baseURL, () { |
|
expect( |
|
WebDavClient.constructUri(baseURL).toString(), |
|
'$sanitizedBaseURL$webdavBase', |
|
); |
|
expect( |
|
WebDavClient.constructUri(baseURL, PathUri.parse('/')).toString(), |
|
'$sanitizedBaseURL$webdavBase', |
|
); |
|
expect( |
|
WebDavClient.constructUri(baseURL, PathUri.parse('test')).toString(), |
|
'$sanitizedBaseURL$webdavBase/test', |
|
); |
|
expect( |
|
WebDavClient.constructUri(baseURL, PathUri.parse('test/')).toString(), |
|
'$sanitizedBaseURL$webdavBase/test', |
|
); |
|
expect( |
|
WebDavClient.constructUri(baseURL, PathUri.parse('/test')).toString(), |
|
'$sanitizedBaseURL$webdavBase/test', |
|
); |
|
expect( |
|
WebDavClient.constructUri(baseURL, PathUri.parse('/test/')).toString(), |
|
'$sanitizedBaseURL$webdavBase/test', |
|
); |
|
}); |
|
} |
|
}); |
|
|
|
group('PathUri', () { |
|
test('isAbsolute', () { |
|
expect(PathUri.parse('').isAbsolute, false); |
|
expect(PathUri.parse('/').isAbsolute, true); |
|
expect(PathUri.parse('test').isAbsolute, false); |
|
expect(PathUri.parse('test/').isAbsolute, false); |
|
expect(PathUri.parse('/test').isAbsolute, true); |
|
expect(PathUri.parse('/test/').isAbsolute, true); |
|
}); |
|
|
|
test('isDirectory', () { |
|
expect(PathUri.parse('').isDirectory, true); |
|
expect(PathUri.parse('/').isDirectory, true); |
|
expect(PathUri.parse('test').isDirectory, false); |
|
expect(PathUri.parse('test/').isDirectory, true); |
|
expect(PathUri.parse('/test').isDirectory, false); |
|
expect(PathUri.parse('/test/').isDirectory, true); |
|
}); |
|
|
|
test('pathSegments', () { |
|
expect(PathUri.parse('').pathSegments, isEmpty); |
|
expect(PathUri.parse('/').pathSegments, isEmpty); |
|
expect(PathUri.parse('test').pathSegments, ['test']); |
|
expect(PathUri.parse('test/').pathSegments, ['test']); |
|
expect(PathUri.parse('/test').pathSegments, ['test']); |
|
expect(PathUri.parse('/test/').pathSegments, ['test']); |
|
}); |
|
|
|
test('path', () { |
|
expect(PathUri.parse('').path, ''); |
|
expect(PathUri.parse('/').path, '/'); |
|
expect(PathUri.parse('test').path, 'test'); |
|
expect(PathUri.parse('test/').path, 'test/'); |
|
expect(PathUri.parse('/test').path, '/test'); |
|
expect(PathUri.parse('/test/').path, '/test/'); |
|
}); |
|
|
|
test('normalization', () { |
|
expect(PathUri.parse('/test/abc/').path, '/test/abc/'); |
|
expect(PathUri.parse('//test//abc//').path, '/test/abc/'); |
|
expect(PathUri.parse('///test///abc///').path, '/test/abc/'); |
|
}); |
|
|
|
test('name', () { |
|
expect(PathUri.parse('').name, ''); |
|
expect(PathUri.parse('test').name, 'test'); |
|
expect(PathUri.parse('/test/').name, 'test'); |
|
expect(PathUri.parse('abc/test').name, 'test'); |
|
expect(PathUri.parse('/abc/test/').name, 'test'); |
|
}); |
|
|
|
test('parent', () { |
|
expect(PathUri.parse('').parent, null); |
|
expect(PathUri.parse('/').parent, null); |
|
expect(PathUri.parse('test').parent, PathUri.parse('')); |
|
expect(PathUri.parse('test/abc').parent, PathUri.parse('test/')); |
|
expect(PathUri.parse('test/abc/').parent, PathUri.parse('test/')); |
|
expect(PathUri.parse('/test/abc').parent, PathUri.parse('/test/')); |
|
expect(PathUri.parse('/test/abc/').parent, PathUri.parse('/test/')); |
|
}); |
|
|
|
test('join', () { |
|
expect(PathUri.parse('').join(PathUri.parse('test')), PathUri.parse('test')); |
|
expect(PathUri.parse('/').join(PathUri.parse('test')), PathUri.parse('/test')); |
|
expect(() => PathUri.parse('test').join(PathUri.parse('abc')), throwsA(isA<StateError>())); |
|
expect(PathUri.parse('test/').join(PathUri.parse('abc')), PathUri.parse('test/abc')); |
|
expect(PathUri.parse('test/').join(PathUri.parse('abc/123')), PathUri.parse('test/abc/123')); |
|
expect(PathUri.parse('/test/').join(PathUri.parse('abc')), PathUri.parse('/test/abc')); |
|
expect(PathUri.parse('/test/').join(PathUri.parse('/abc')), PathUri.parse('/test/abc')); |
|
expect(PathUri.parse('/test/').join(PathUri.parse('/abc/')), PathUri.parse('/test/abc/')); |
|
}); |
|
|
|
test('rename', () { |
|
expect(PathUri.parse('').rename('test'), PathUri.parse('')); |
|
expect(PathUri.parse('test').rename('abc'), PathUri.parse('abc')); |
|
expect(PathUri.parse('test/').rename('abc'), PathUri.parse('abc/')); |
|
expect(PathUri.parse('test/abc').rename('123'), PathUri.parse('test/123')); |
|
expect(PathUri.parse('test/abc/').rename('123'), PathUri.parse('test/123/')); |
|
expect(() => PathUri.parse('test').rename('abc/'), throwsA(isA<Exception>())); |
|
expect(() => PathUri.parse('test/').rename('abc/'), throwsA(isA<Exception>())); |
|
expect(() => PathUri.parse('test').rename('/abc'), throwsA(isA<Exception>())); |
|
expect(() => PathUri.parse('test/').rename('/abc'), throwsA(isA<Exception>())); |
|
expect(() => PathUri.parse('test').rename('abc/123'), throwsA(isA<Exception>())); |
|
expect(() => PathUri.parse('test/').rename('abc/123'), throwsA(isA<Exception>())); |
|
}); |
|
}); |
|
|
|
group( |
|
'webdav', |
|
() { |
|
late DockerContainer container; |
|
late NextcloudClient client; |
|
|
|
setUp(() async { |
|
container = await DockerContainer.create(); |
|
client = await TestNextcloudClient.create(container); |
|
}); |
|
tearDown(() => container.destroy()); |
|
|
|
test('List directory', () async { |
|
final responses = (await client.webdav.propfind( |
|
PathUri.parse('/'), |
|
prop: WebDavPropWithoutValues.fromBools( |
|
nchaspreview: true, |
|
davgetcontenttype: true, |
|
davgetlastmodified: true, |
|
ocsize: true, |
|
), |
|
)) |
|
.responses; |
|
expect(responses, hasLength(10)); |
|
final props = |
|
responses.singleWhere((final response) => response.href!.endsWith('/Nextcloud.png')).propstats.first.prop; |
|
expect(props.nchaspreview, isTrue); |
|
expect(props.davgetcontenttype, 'image/png'); |
|
expect(webdavDateFormat.parseUtc(props.davgetlastmodified!).isBefore(DateTime.now()), isTrue); |
|
expect(props.ocsize, 50598); |
|
}); |
|
|
|
test('List directory recursively', () async { |
|
final responses = (await client.webdav.propfind( |
|
PathUri.parse('/'), |
|
depth: WebDavDepth.infinity, |
|
)) |
|
.responses; |
|
expect(responses, hasLength(48)); |
|
}); |
|
|
|
test('Get file props', () async { |
|
final response = (await client.webdav.propfind( |
|
PathUri.parse('Nextcloud.png'), |
|
prop: WebDavPropWithoutValues.fromBools( |
|
davgetlastmodified: true, |
|
davgetetag: true, |
|
davgetcontenttype: true, |
|
davgetcontentlength: true, |
|
davresourcetype: true, |
|
ocid: true, |
|
ocfileid: true, |
|
ocfavorite: true, |
|
occommentshref: true, |
|
occommentscount: true, |
|
occommentsunread: true, |
|
ocdownloadurl: true, |
|
ocownerid: true, |
|
ocownerdisplayname: true, |
|
ocsize: true, |
|
ocpermissions: true, |
|
ncnote: true, |
|
ncdatafingerprint: true, |
|
nchaspreview: true, |
|
ncmounttype: true, |
|
ncisencrypted: true, |
|
ncmetadataetag: true, |
|
ncuploadtime: true, |
|
nccreationtime: true, |
|
ncrichworkspace: true, |
|
ocssharepermissions: true, |
|
ocmsharepermissions: true, |
|
), |
|
)) |
|
.toWebDavFiles() |
|
.single; |
|
|
|
expect(response.path, PathUri.parse('Nextcloud.png')); |
|
expect(response.id, isNotEmpty); |
|
expect(response.fileId, isNotEmpty); |
|
expect(response.isCollection, isFalse); |
|
expect(response.mimeType, 'image/png'); |
|
expect(response.etag, isNotEmpty); |
|
expect(response.size, 50598); |
|
expect(response.ownerId, 'user1'); |
|
expect(response.ownerDisplay, 'User One'); |
|
expect(response.lastModified!.isBefore(DateTime.now()), isTrue); |
|
expect(response.isDirectory, isFalse); |
|
expect(response.uploadedDate, DateTime.utc(1970)); |
|
expect(response.createdDate, DateTime.utc(1970)); |
|
expect(response.favorite, isFalse); |
|
expect(response.hasPreview, isTrue); |
|
expect(response.name, 'Nextcloud.png'); |
|
expect(response.isDirectory, isFalse); |
|
|
|
expect(webdavDateFormat.parseUtc(response.props.davgetlastmodified!).isBefore(DateTime.now()), isTrue); |
|
expect(response.props.davgetetag, isNotEmpty); |
|
expect(response.props.davgetcontenttype, 'image/png'); |
|
expect(response.props.davgetcontentlength, 50598); |
|
expect(response.props.davresourcetype!.collection, isNull); |
|
expect(response.props.ocid, isNotEmpty); |
|
expect(response.props.ocfileid, isNotEmpty); |
|
expect(response.props.ocfavorite, 0); |
|
expect(response.props.occommentshref, isNotEmpty); |
|
expect(response.props.occommentscount, 0); |
|
expect(response.props.occommentsunread, 0); |
|
expect(response.props.ocdownloadurl, isNull); |
|
expect(response.props.ocownerid, 'user1'); |
|
expect(response.props.ocownerdisplayname, 'User One'); |
|
expect(response.props.ocsize, 50598); |
|
expect(response.props.ocpermissions, 'RGDNVW'); |
|
expect(response.props.ncnote, isNull); |
|
expect(response.props.ncdatafingerprint, isNull); |
|
expect(response.props.nchaspreview, isTrue); |
|
expect(response.props.ncmounttype, isNull); |
|
expect(response.props.ncisencrypted, isNull); |
|
expect(response.props.ncmetadataetag, isNull); |
|
expect(response.props.ncuploadtime, 0); |
|
expect(response.props.nccreationtime, 0); |
|
expect(response.props.ncrichworkspace, isNull); |
|
expect(response.props.ocssharepermissions, 19); |
|
expect(json.decode(response.props.ocmsharepermissions!), ['share', 'read', 'write']); |
|
}); |
|
|
|
test('Get directory props', () async { |
|
final data = utf8.encode('test'); |
|
await client.webdav.mkcol(PathUri.parse('test')); |
|
await client.webdav.put(data, PathUri.parse('test/test.txt')); |
|
|
|
final response = (await client.webdav.propfind( |
|
PathUri.parse('test'), |
|
prop: WebDavPropWithoutValues.fromBools( |
|
davgetcontenttype: true, |
|
davgetlastmodified: true, |
|
davresourcetype: true, |
|
ocsize: true, |
|
), |
|
depth: WebDavDepth.zero, |
|
)) |
|
.toWebDavFiles() |
|
.single; |
|
|
|
expect(response.path, PathUri.parse('test/')); |
|
expect(response.isCollection, isTrue); |
|
expect(response.mimeType, isNull); |
|
expect(response.size, data.lengthInBytes); |
|
expect( |
|
response.lastModified!.millisecondsSinceEpoch, |
|
closeTo(DateTime.now().millisecondsSinceEpoch, 10E3), |
|
); |
|
expect(response.name, 'test'); |
|
expect(response.isDirectory, isTrue); |
|
|
|
expect(response.props.davgetcontenttype, isNull); |
|
expect( |
|
webdavDateFormat.parseUtc(response.props.davgetlastmodified!).millisecondsSinceEpoch, |
|
closeTo(DateTime.now().millisecondsSinceEpoch, 10E3), |
|
); |
|
expect(response.props.davresourcetype!.collection, isNotNull); |
|
expect(response.props.ocsize, data.lengthInBytes); |
|
}); |
|
|
|
test('Filter files', () async { |
|
final response = await client.webdav.put(utf8.encode('test'), PathUri.parse('test.txt')); |
|
final id = response.headers['oc-fileid']!.first; |
|
await client.webdav.proppatch( |
|
PathUri.parse('test.txt'), |
|
set: WebDavProp( |
|
ocfavorite: 1, |
|
), |
|
); |
|
|
|
final responses = (await client.webdav.report( |
|
PathUri.parse('/'), |
|
WebDavOcFilterRules( |
|
ocfavorite: 1, |
|
), |
|
prop: WebDavPropWithoutValues.fromBools( |
|
ocid: true, |
|
ocfavorite: true, |
|
), |
|
)) |
|
.responses; |
|
expect(responses, hasLength(1)); |
|
final props = |
|
responses.singleWhere((final response) => response.href!.endsWith('/test.txt')).propstats.first.prop; |
|
expect(props.ocid, id); |
|
expect(props.ocfavorite, 1); |
|
}); |
|
|
|
test('Set properties', () async { |
|
final lastModifiedDate = DateTime.utc(1972, 3); |
|
final createdDate = DateTime.utc(1971, 2); |
|
final uploadTime = DateTime.now(); |
|
|
|
await client.webdav.put( |
|
utf8.encode('test'), |
|
PathUri.parse('test.txt'), |
|
lastModified: lastModifiedDate, |
|
created: createdDate, |
|
); |
|
|
|
final updated = await client.webdav.proppatch( |
|
PathUri.parse('test.txt'), |
|
set: WebDavProp( |
|
ocfavorite: 1, |
|
), |
|
); |
|
expect(updated, isTrue); |
|
|
|
final props = (await client.webdav.propfind( |
|
PathUri.parse('test.txt'), |
|
prop: WebDavPropWithoutValues.fromBools( |
|
ocfavorite: true, |
|
davgetlastmodified: true, |
|
nccreationtime: true, |
|
ncuploadtime: true, |
|
), |
|
)) |
|
.responses |
|
.single |
|
.propstats |
|
.first |
|
.prop; |
|
expect(props.ocfavorite, 1); |
|
expect(webdavDateFormat.parseUtc(props.davgetlastmodified!), lastModifiedDate); |
|
expect(props.nccreationtime! * 1000, createdDate.millisecondsSinceEpoch); |
|
expect(props.ncuploadtime! * 1000, closeTo(uploadTime.millisecondsSinceEpoch, 10E3)); |
|
}); |
|
|
|
test('Remove properties', () async { |
|
await client.webdav.put(utf8.encode('test'), PathUri.parse('test.txt')); |
|
|
|
var updated = await client.webdav.proppatch( |
|
PathUri.parse('test.txt'), |
|
set: WebDavProp( |
|
ocfavorite: 1, |
|
), |
|
); |
|
expect(updated, isTrue); |
|
|
|
var props = (await client.webdav.propfind( |
|
PathUri.parse('test.txt'), |
|
prop: WebDavPropWithoutValues.fromBools( |
|
ocfavorite: true, |
|
nccreationtime: true, |
|
ncuploadtime: true, |
|
), |
|
)) |
|
.responses |
|
.single |
|
.propstats |
|
.first |
|
.prop; |
|
expect(props.ocfavorite, 1); |
|
|
|
updated = await client.webdav.proppatch( |
|
PathUri.parse('test.txt'), |
|
remove: WebDavPropWithoutValues.fromBools( |
|
ocfavorite: true, |
|
), |
|
); |
|
expect(updated, isFalse); |
|
|
|
props = (await client.webdav.propfind( |
|
PathUri.parse('test.txt'), |
|
prop: WebDavPropWithoutValues.fromBools( |
|
ocfavorite: true, |
|
), |
|
)) |
|
.responses |
|
.single |
|
.propstats |
|
.first |
|
.prop; |
|
expect(props.ocfavorite, 0); |
|
}); |
|
|
|
test('Upload and download file', () async { |
|
final destinationDir = Directory.systemTemp.createTempSync(); |
|
final destination = File('${destinationDir.path}/test.png'); |
|
final source = File('test/files/test.png'); |
|
final progressValues = <double>[]; |
|
|
|
await client.webdav.putFile( |
|
source, |
|
source.statSync(), |
|
PathUri.parse('test.png'), |
|
onProgress: progressValues.add, |
|
); |
|
await client.webdav.getFile( |
|
PathUri.parse('test.png'), |
|
destination, |
|
onProgress: progressValues.add, |
|
); |
|
expect(progressValues, containsAll([1.0, 1.0])); |
|
expect(destination.readAsBytesSync(), source.readAsBytesSync()); |
|
|
|
destinationDir.deleteSync(recursive: true); |
|
}); |
|
|
|
group('litmus', () { |
|
group('basic', () { |
|
test('options', () async { |
|
final options = await client.webdav.options(); |
|
expect(options.capabilities, contains('1')); |
|
expect(options.capabilities, contains('3')); |
|
// Nextcloud only contains a fake plugin for Class 2 support: https://github.com/nextcloud/server/blob/master/apps/dav/lib/Connector/Sabre/FakeLockerPlugin.php |
|
// It does not actually support locking and is only there for compatibility reasons. |
|
expect(options.capabilities, isNot(contains('2'))); |
|
}); |
|
|
|
for (final (name, path) in [ |
|
('put_get', 'res'), |
|
('put_get_utf8_segment', 'res-%e2%82%ac'), |
|
]) { |
|
test(name, () async { |
|
final content = utf8.encode('This is a test file'); |
|
|
|
final response = await client.webdav.put(content, PathUri.parse(path)); |
|
expect(response.statusCode, 201); |
|
|
|
final downloadedContent = await client.webdav.get(PathUri.parse(path)); |
|
expect(downloadedContent, equals(content)); |
|
}); |
|
} |
|
|
|
test('put_no_parent', () async { |
|
expect( |
|
() => client.webdav.put(Uint8List(0), PathUri.parse('409me/noparent.txt')), |
|
// https://github.com/nextcloud/server/issues/39625 |
|
throwsA(predicate<DynamiteApiException>((final e) => e.statusCode == 409)), |
|
); |
|
}); |
|
|
|
test('delete', () async { |
|
await client.webdav.put(Uint8List(0), PathUri.parse('test.txt')); |
|
|
|
final response = await client.webdav.delete(PathUri.parse('test.txt')); |
|
expect(response.statusCode, 204); |
|
}); |
|
|
|
test('delete_null', () async { |
|
expect( |
|
() => client.webdav.delete(PathUri.parse('test.txt')), |
|
throwsA(predicate<DynamiteApiException>((final e) => e.statusCode == 404)), |
|
); |
|
}); |
|
|
|
// delete_fragment: This test is not applicable because the fragment is already removed on the client side |
|
|
|
test('mkcol', () async { |
|
final response = await client.webdav.mkcol(PathUri.parse('test')); |
|
expect(response.statusCode, 201); |
|
}); |
|
|
|
test('mkcol_again', () async { |
|
await client.webdav.mkcol(PathUri.parse('test')); |
|
|
|
expect( |
|
() => client.webdav.mkcol(PathUri.parse('test')), |
|
throwsA(predicate<DynamiteApiException>((final e) => e.statusCode == 405)), |
|
); |
|
}); |
|
|
|
test('delete_coll', () async { |
|
var response = await client.webdav.mkcol(PathUri.parse('test')); |
|
|
|
response = await client.webdav.delete(PathUri.parse('test')); |
|
expect(response.statusCode, 204); |
|
}); |
|
|
|
test('mkcol_no_parent', () async { |
|
expect( |
|
() => client.webdav.mkcol(PathUri.parse('409me/noparent')), |
|
throwsA(predicate<DynamiteApiException>((final e) => e.statusCode == 409)), |
|
); |
|
}); |
|
|
|
// mkcol_with_body: This test is not applicable because we only write valid request bodies |
|
}); |
|
|
|
group('copymove', () { |
|
test('copy_simple', () async { |
|
await client.webdav.mkcol(PathUri.parse('src')); |
|
|
|
final response = await client.webdav.copy(PathUri.parse('src'), PathUri.parse('dst')); |
|
expect(response.statusCode, 201); |
|
}); |
|
|
|
test('copy_overwrite', () async { |
|
await client.webdav.mkcol(PathUri.parse('src')); |
|
await client.webdav.mkcol(PathUri.parse('dst')); |
|
|
|
expect( |
|
() => client.webdav.copy(PathUri.parse('src'), PathUri.parse('dst')), |
|
throwsA(predicate<DynamiteApiException>((final e) => e.statusCode == 412)), |
|
); |
|
|
|
final response = await client.webdav.copy(PathUri.parse('src'), PathUri.parse('dst'), overwrite: true); |
|
expect(response.statusCode, 204); |
|
}); |
|
|
|
test('copy_nodestcoll', () async { |
|
await client.webdav.mkcol(PathUri.parse('src')); |
|
|
|
expect( |
|
() => client.webdav.copy(PathUri.parse('src'), PathUri.parse('nonesuch/dst')), |
|
throwsA(predicate<DynamiteApiException>((final e) => e.statusCode == 409)), |
|
); |
|
}); |
|
|
|
test('copy_coll', () async { |
|
await client.webdav.mkcol(PathUri.parse('src')); |
|
await client.webdav.mkcol(PathUri.parse('src/sub')); |
|
for (var i = 0; i < 10; i++) { |
|
await client.webdav.put(Uint8List(0), PathUri.parse('src/$i.txt')); |
|
} |
|
await client.webdav.copy(PathUri.parse('src'), PathUri.parse('dst1')); |
|
await client.webdav.copy(PathUri.parse('src'), PathUri.parse('dst2')); |
|
|
|
expect( |
|
() => client.webdav.copy(PathUri.parse('src'), PathUri.parse('dst1')), |
|
throwsA(predicate<DynamiteApiException>((final e) => e.statusCode == 412)), |
|
); |
|
|
|
var response = await client.webdav.copy(PathUri.parse('src'), PathUri.parse('dst2'), overwrite: true); |
|
expect(response.statusCode, 204); |
|
|
|
for (var i = 0; i < 10; i++) { |
|
response = await client.webdav.delete(PathUri.parse('dst1/$i.txt')); |
|
expect(response.statusCode, 204); |
|
} |
|
|
|
response = await client.webdav.delete(PathUri.parse('dst1/sub')); |
|
expect(response.statusCode, 204); |
|
|
|
response = await client.webdav.delete(PathUri.parse('dst2')); |
|
expect(response.statusCode, 204); |
|
}); |
|
|
|
// copy_shallow: Does not work on litmus, let's wait for https://github.com/nextcloud/server/issues/39627 |
|
|
|
test('move', () async { |
|
await client.webdav.put(Uint8List(0), PathUri.parse('src1.txt')); |
|
await client.webdav.put(Uint8List(0), PathUri.parse('src2.txt')); |
|
await client.webdav.mkcol(PathUri.parse('coll')); |
|
|
|
var response = await client.webdav.move(PathUri.parse('src1.txt'), PathUri.parse('dst.txt')); |
|
expect(response.statusCode, 201); |
|
|
|
expect( |
|
() => client.webdav.move(PathUri.parse('src2.txt'), PathUri.parse('dst.txt')), |
|
throwsA(predicate<DynamiteApiException>((final e) => e.statusCode == 412)), |
|
); |
|
|
|
response = await client.webdav.move(PathUri.parse('src2.txt'), PathUri.parse('dst.txt'), overwrite: true); |
|
expect(response.statusCode, 204); |
|
}); |
|
|
|
test('move_coll', () async { |
|
await client.webdav.mkcol(PathUri.parse('src')); |
|
await client.webdav.mkcol(PathUri.parse('src/sub')); |
|
for (var i = 0; i < 10; i++) { |
|
await client.webdav.put(Uint8List(0), PathUri.parse('src/$i.txt')); |
|
} |
|
await client.webdav.put(Uint8List(0), PathUri.parse('noncoll')); |
|
await client.webdav.copy(PathUri.parse('src'), PathUri.parse('dst2')); |
|
await client.webdav.move(PathUri.parse('src'), PathUri.parse('dst1')); |
|
|
|
expect( |
|
() => client.webdav.move(PathUri.parse('dst1'), PathUri.parse('dst2')), |
|
throwsA(predicate<DynamiteApiException>((final e) => e.statusCode == 412)), |
|
); |
|
|
|
await client.webdav.move(PathUri.parse('dst2'), PathUri.parse('dst1'), overwrite: true); |
|
await client.webdav.copy(PathUri.parse('dst1'), PathUri.parse('dst2')); |
|
|
|
for (var i = 0; i < 10; i++) { |
|
final response = await client.webdav.delete(PathUri.parse('dst1/$i.txt')); |
|
expect(response.statusCode, 204); |
|
} |
|
|
|
final response = await client.webdav.delete(PathUri.parse('dst1/sub')); |
|
expect(response.statusCode, 204); |
|
|
|
expect( |
|
() => client.webdav.move(PathUri.parse('dst2'), PathUri.parse('noncoll')), |
|
throwsA(predicate<DynamiteApiException>((final e) => e.statusCode == 412)), |
|
); |
|
}); |
|
}); |
|
|
|
group('largefile', () { |
|
final largefileSize = pow(10, 9).toInt(); // 1GB |
|
|
|
// large_put: Already covered by large_get |
|
|
|
test('large_get', () async { |
|
final response = await client.webdav.put(Uint8List(largefileSize), PathUri.parse('test.txt')); |
|
expect(response.statusCode, 201); |
|
|
|
final downloadedContent = await client.webdav.get(PathUri.parse('test.txt')); |
|
expect(downloadedContent, hasLength(largefileSize)); |
|
}); |
|
}); |
|
|
|
// props: Most of them are either not applicable or hard/impossible to implement because we don't allow just writing any props |
|
}); |
|
}, |
|
retry: retryCount, |
|
timeout: timeout, |
|
); |
|
}
|
|
|