From 5051ce16ce4ed366ef284cbb3f320721f3550749 Mon Sep 17 00:00:00 2001 From: jld3103 Date: Wed, 1 Nov 2023 10:03:15 +0100 Subject: [PATCH] refactor(nextcloud): Rely on prebuilt docker image for testing Signed-off-by: jld3103 --- packages/nextcloud/test/core_test.dart | 5 +- packages/nextcloud/test/dashboard_test.dart | 5 +- packages/nextcloud/test/helper.dart | 50 +++++++------------ packages/nextcloud/test/news_test.dart | 7 +-- packages/nextcloud/test/notes_test.dart | 5 +- .../nextcloud/test/notifications_test.dart | 10 +--- .../nextcloud/test/provisioning_api_test.dart | 5 +- packages/nextcloud/test/settings_test.dart | 47 ++++++++--------- packages/nextcloud/test/spreed_test.dart | 5 +- packages/nextcloud/test/uppush_test.dart | 5 +- packages/nextcloud/test/user_status_test.dart | 5 +- packages/nextcloud/test/webdav_test.dart | 5 +- 12 files changed, 54 insertions(+), 100 deletions(-) diff --git a/packages/nextcloud/test/core_test.dart b/packages/nextcloud/test/core_test.dart index 0c874beb5aa..dbe9954a7f5 100644 --- a/packages/nextcloud/test/core_test.dart +++ b/packages/nextcloud/test/core_test.dart @@ -8,13 +8,10 @@ void main() { group( 'core', () { - late DockerImage image; - setUpAll(() async => image = await getDockerImage()); - late DockerContainer container; late TestNextcloudClient client; setUp(() async { - container = await getDockerContainer(image); + container = await getDockerContainer(); client = await getTestClient(container); }); tearDown(() => container.destroy()); diff --git a/packages/nextcloud/test/dashboard_test.dart b/packages/nextcloud/test/dashboard_test.dart index ca18058adba..97ba4f1a70b 100644 --- a/packages/nextcloud/test/dashboard_test.dart +++ b/packages/nextcloud/test/dashboard_test.dart @@ -7,13 +7,10 @@ void main() { group( 'dashboard', () { - late DockerImage image; - setUpAll(() async => image = await getDockerImage()); - late DockerContainer container; late TestNextcloudClient client; setUp(() async { - container = await getDockerContainer(image); + container = await getDockerContainer(); client = await getTestClient(container); }); tearDown(() => container.destroy()); diff --git a/packages/nextcloud/test/helper.dart b/packages/nextcloud/test/helper.dart index 561494cbf35..a2462fd24a9 100644 --- a/packages/nextcloud/test/helper.dart +++ b/packages/nextcloud/test/helper.dart @@ -156,8 +156,25 @@ Future getTestClient( return client; } -Future getDockerContainer(final DockerImage image) async { +Future getDockerContainer() async { + const dockerImageName = 'ghcr.io/nextcloud/neon/dev'; + late ProcessResult result; + result = await runExecutableArguments( + 'docker', + [ + 'images', + '-q', + dockerImageName, + ], + ); + if (result.exitCode != 0) { + throw Exception('Querying docker image failed: ${result.stderr}'); + } + if (result.stdout.toString().isEmpty) { + throw Exception('Missing docker image $dockerImageName. Please build it using ./tool/build-dev-container.sh'); + } + late int port; while (true) { port = randomPort(); @@ -171,7 +188,7 @@ Future getDockerContainer(final DockerImage image) async { 'host.docker.internal:host-gateway', '-p', '$port:80', - image, + dockerImageName, ], ); // 125 means the docker run command itself has failed which indicated the port is already used @@ -190,35 +207,6 @@ Future getDockerContainer(final DockerImage image) async { ); } -typedef DockerImage = String; - -Future getDockerImage() async { - const dockerImageName = 'nextcloud-neon-dev'; - - final inputStream = StreamController>(); - final process = runExecutableArguments( - 'docker', - [ - 'build', - '-t', - dockerImageName, - '-f', - '-', - '../../tool', - ], - stdin: inputStream.stream, - ); - inputStream.add(utf8.encode(File('../../tool/Dockerfile.dev').readAsStringSync())); - await inputStream.close(); - - final result = await process; - if (result.exitCode != 0) { - throw Exception('Failed to build docker image'); - } - - return dockerImageName; -} - class TestNextcloudUser { TestNextcloudUser( this.username, diff --git a/packages/nextcloud/test/news_test.dart b/packages/nextcloud/test/news_test.dart index ef2a8ec09dc..b3ef3fd1205 100644 --- a/packages/nextcloud/test/news_test.dart +++ b/packages/nextcloud/test/news_test.dart @@ -10,15 +10,10 @@ void main() { group( 'news', () { - late DockerImage image; - setUpAll(() async { - image = await getDockerImage(); - }); - late DockerContainer container; late TestNextcloudClient client; setUp(() async { - container = await getDockerContainer(image); + container = await getDockerContainer(); client = await getTestClient(container); }); tearDown(() => container.destroy()); diff --git a/packages/nextcloud/test/notes_test.dart b/packages/nextcloud/test/notes_test.dart index 1d49683ea20..bc80c6fb5ad 100644 --- a/packages/nextcloud/test/notes_test.dart +++ b/packages/nextcloud/test/notes_test.dart @@ -9,13 +9,10 @@ void main() { group( 'notes', () { - late DockerImage image; - setUpAll(() async => image = await getDockerImage()); - late DockerContainer container; late TestNextcloudClient client; setUp(() async { - container = await getDockerContainer(image); + container = await getDockerContainer(); client = await getTestClient(container); }); tearDown(() => container.destroy()); diff --git a/packages/nextcloud/test/notifications_test.dart b/packages/nextcloud/test/notifications_test.dart index 093423e3160..0520bf84881 100644 --- a/packages/nextcloud/test/notifications_test.dart +++ b/packages/nextcloud/test/notifications_test.dart @@ -7,13 +7,10 @@ import 'helper.dart'; void main() { group('notifications', () { - late DockerImage image; - setUpAll(() async => image = await getDockerImage()); - late DockerContainer container; late TestNextcloudClient client; setUp(() async { - container = await getDockerContainer(image); + container = await getDockerContainer(); client = await getTestClient( container, username: 'admin', @@ -103,13 +100,10 @@ void main() { }); group('Push', () { - late DockerImage image; - setUpAll(() async => image = await getDockerImage()); - late DockerContainer container; late TestNextcloudClient client; setUp(() async { - container = await getDockerContainer(image); + container = await getDockerContainer(); client = await getTestClient( container, username: 'admin', diff --git a/packages/nextcloud/test/provisioning_api_test.dart b/packages/nextcloud/test/provisioning_api_test.dart index 067b444692b..6f175ced215 100644 --- a/packages/nextcloud/test/provisioning_api_test.dart +++ b/packages/nextcloud/test/provisioning_api_test.dart @@ -7,13 +7,10 @@ void main() { group( 'provisioning_api', () { - late DockerImage image; - setUpAll(() async => image = await getDockerImage()); - late DockerContainer container; late TestNextcloudClient client; setUp(() async { - container = await getDockerContainer(image); + container = await getDockerContainer(); client = await getTestClient( container, username: 'admin', diff --git a/packages/nextcloud/test/settings_test.dart b/packages/nextcloud/test/settings_test.dart index 4a60ef5cab8..9ad425089f0 100644 --- a/packages/nextcloud/test/settings_test.dart +++ b/packages/nextcloud/test/settings_test.dart @@ -5,29 +5,30 @@ import 'package:test/test.dart'; import 'helper.dart'; -Future main() async { - await run(await getDockerImage()); -} - -Future run(final DockerImage image) async { - group('settings', () { - late DockerContainer container; - late TestNextcloudClient client; - setUp(() async { - container = await getDockerContainer(image); - client = await getTestClient( - container, - username: 'admin', - ); - }); - tearDown(() => container.destroy()); +void main() { + group( + 'settings', + () { + late DockerContainer container; + late TestNextcloudClient client; + setUp(() async { + container = await getDockerContainer(); + client = await getTestClient( + container, + username: 'admin', + ); + }); + tearDown(() => container.destroy()); - group('Logs', () { - test('Download', () async { - final response = await client.settings.logSettings.download(); - final logs = utf8.decode(response.body); - expect(logs, await container.nextcloudLogs()); + group('Logs', () { + test('Download', () async { + final response = await client.settings.logSettings.download(); + final logs = utf8.decode(response.body); + expect(logs, await container.nextcloudLogs()); + }); }); - }); - }); + }, + retry: retryCount, + timeout: timeout, + ); } diff --git a/packages/nextcloud/test/spreed_test.dart b/packages/nextcloud/test/spreed_test.dart index d9559464d1c..2b88772e8cd 100644 --- a/packages/nextcloud/test/spreed_test.dart +++ b/packages/nextcloud/test/spreed_test.dart @@ -12,13 +12,10 @@ void main() { group( 'spreed', () { - late DockerImage image; - setUpAll(() async => image = await getDockerImage()); - late DockerContainer container; late TestNextcloudClient client1; setUp(() async { - container = await getDockerContainer(image); + container = await getDockerContainer(); client1 = await getTestClient(container); }); tearDown(() => container.destroy()); diff --git a/packages/nextcloud/test/uppush_test.dart b/packages/nextcloud/test/uppush_test.dart index dd93f61fb11..2ecd3e7fb6a 100644 --- a/packages/nextcloud/test/uppush_test.dart +++ b/packages/nextcloud/test/uppush_test.dart @@ -7,13 +7,10 @@ void main() { group( 'uppush', () { - late DockerImage image; - setUpAll(() async => image = await getDockerImage()); - late DockerContainer container; late TestNextcloudClient client; setUp(() async { - container = await getDockerContainer(image); + container = await getDockerContainer(); client = await getTestClient( container, username: 'admin', diff --git a/packages/nextcloud/test/user_status_test.dart b/packages/nextcloud/test/user_status_test.dart index 279442dc90b..b53905f93af 100644 --- a/packages/nextcloud/test/user_status_test.dart +++ b/packages/nextcloud/test/user_status_test.dart @@ -7,13 +7,10 @@ void main() { group( 'user_status', () { - late DockerImage image; - setUpAll(() async => image = await getDockerImage()); - late DockerContainer container; late TestNextcloudClient client; setUp(() async { - container = await getDockerContainer(image); + container = await getDockerContainer(); client = await getTestClient(container); }); tearDown(() => container.destroy()); diff --git a/packages/nextcloud/test/webdav_test.dart b/packages/nextcloud/test/webdav_test.dart index bfc3eeea4b1..523ddc40a24 100644 --- a/packages/nextcloud/test/webdav_test.dart +++ b/packages/nextcloud/test/webdav_test.dart @@ -26,14 +26,11 @@ void main() { group( 'webdav', () { - late DockerImage image; - setUpAll(() async => image = await getDockerImage()); - late DockerContainer container; late TestNextcloudClient client; setUp(() async { - container = await getDockerContainer(image); + container = await getDockerContainer(); client = await getTestClient(container); }); tearDown(() => container.destroy());