From 99f6becd51a1294aa25b8d2577b76ebfa69d7fff Mon Sep 17 00:00:00 2001 From: Gibah Joseph Date: Wed, 6 Nov 2024 19:24:21 +0000 Subject: [PATCH] fix(cli): Fixed additionalCommands in config not appending to generator commands --- openapi-generator-cli/bin/main.dart | 2 +- .../test/openapi_generator_cli_test.dart | 44 +++++++++++++++++++ 2 files changed, 45 insertions(+), 1 deletion(-) diff --git a/openapi-generator-cli/bin/main.dart b/openapi-generator-cli/bin/main.dart index daf1f35..ed23e47 100644 --- a/openapi-generator-cli/bin/main.dart +++ b/openapi-generator-cli/bin/main.dart @@ -209,8 +209,8 @@ Future runMain({ // Prepare additional arguments, excluding the --config flag and its value final filteredArguments = [ - ...additionalCommands.split(' '), ...arguments.where((arg) => arg != '--config' && arg != configFilePath), + additionalCommands, ]; // Execute with classpath diff --git a/openapi-generator-cli/test/openapi_generator_cli_test.dart b/openapi-generator-cli/test/openapi_generator_cli_test.dart index 9056b83..f71f878 100644 --- a/openapi-generator-cli/test/openapi_generator_cli_test.dart +++ b/openapi-generator-cli/test/openapi_generator_cli_test.dart @@ -203,6 +203,50 @@ void main() { expect(exitCode, equals(1)); expect(logBuffer.toString(), contains('Error: FileSystemException')); }); + + // New Test: Check execution of additional commands from config + test( + 'additional commands in config are appended to end of generation command.', + () async { + final mockCommands = 'validate generate'; + final configData = { + ConfigKeys.openapiGeneratorVersion: '5.0.0', + ConfigKeys.additionalCommands: mockCommands, + ConfigKeys.jarCachePath: '.dart_tool/openapi_generator_cache', + }; + + var executedCommands = []; + Future mockExecuteWithClasspath( + List jarPaths, List args) async { + executedCommands.addAll(args); + } + + await runMain( + arguments: ['gen'], + loadConfig: (p0) async => configData, + downloadJar: (p0, p1) async {}, + executeWithClasspath: mockExecuteWithClasspath, + log: (p0) => print(p0), + ); + + // Verify commands executed from config + expect(executedCommands, equals(['gen', 'validate generate'])); + }); + + test('ProcessRunner run method executes and prints out dart version', + () async { + // Define the expected input arguments + const executable = 'dart'; + final arguments = ['--version']; + + // Create an instance of ProcessRunner + final processRunner = ProcessRunner(); + + // Execute the run method and verify the result + final result = await processRunner.run(executable, arguments); + expect(result.stdout, contains('Dart SDK version')); + expect(result.exitCode, equals(0)); + }); } class TestProcessRunner extends ProcessRunner {