| // Copyright 2013 The Flutter Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| import 'package:flutter_migrate/src/base/context.dart'; |
| import 'package:flutter_migrate/src/base/file_system.dart'; |
| import 'package:flutter_migrate/src/base/logger.dart'; |
| import 'package:flutter_migrate/src/base/signals.dart'; |
| import 'package:flutter_migrate/src/commands/status.dart'; |
| import 'package:flutter_migrate/src/utils.dart'; |
| import 'package:process/process.dart'; |
| |
| import 'src/common.dart'; |
| import 'src/context.dart'; |
| import 'src/test_flutter_command_runner.dart'; |
| |
| void main() { |
| late FileSystem fileSystem; |
| late BufferLogger logger; |
| late ProcessManager processManager; |
| late Directory appDir; |
| |
| setUp(() { |
| fileSystem = LocalFileSystem.test(signals: LocalSignals.instance); |
| appDir = fileSystem.systemTempDirectory.createTempSync('apptestdir'); |
| logger = BufferLogger.test(); |
| processManager = const LocalProcessManager(); |
| }); |
| |
| tearDown(() async { |
| tryToDelete(appDir); |
| }); |
| |
| testUsingContext('Status produces all outputs', () async { |
| final MigrateStatusCommand command = MigrateStatusCommand( |
| verbose: true, |
| logger: logger, |
| fileSystem: fileSystem, |
| processManager: processManager, |
| ); |
| final Directory stagingDir = |
| appDir.childDirectory(kDefaultMigrateStagingDirectoryName); |
| final File pubspecOriginal = appDir.childFile('pubspec.yaml'); |
| pubspecOriginal.createSync(); |
| pubspecOriginal.writeAsStringSync(''' |
| name: originalname |
| description: A new Flutter project. |
| version: 1.0.0+1 |
| environment: |
| sdk: '>=2.18.0-58.0.dev <3.0.0' |
| dependencies: |
| flutter: |
| sdk: flutter |
| dev_dependencies: |
| flutter_test: |
| sdk: flutter |
| flutter: |
| uses-material-design: true''', flush: true); |
| |
| final File pubspecModified = stagingDir.childFile('pubspec.yaml'); |
| pubspecModified.createSync(recursive: true); |
| pubspecModified.writeAsStringSync(''' |
| name: newname |
| description: new description of the test project |
| version: 1.0.0+1 |
| environment: |
| sdk: '>=2.18.0-58.0.dev <3.0.0' |
| dependencies: |
| flutter: |
| sdk: flutter |
| dev_dependencies: |
| flutter_test: |
| sdk: flutter |
| flutter: |
| uses-material-design: false |
| EXTRALINE''', flush: true); |
| |
| final File addedFile = stagingDir.childFile('added.file'); |
| addedFile.createSync(recursive: true); |
| addedFile.writeAsStringSync('new file contents'); |
| |
| final File manifestFile = stagingDir.childFile('.migrate_manifest'); |
| manifestFile.createSync(recursive: true); |
| manifestFile.writeAsStringSync(''' |
| merged_files: |
| - pubspec.yaml |
| conflict_files: |
| added_files: |
| - added.file |
| deleted_files: |
| '''); |
| |
| await createTestCommandRunner(command).run(<String>[ |
| 'status', |
| '--staging-directory=${stagingDir.path}', |
| '--project-directory=${appDir.path}', |
| '--flutter-subcommand', |
| ]); |
| |
| expect(logger.statusText, contains(''' |
| Newly added file at added.file: |
| |
| new file contents''')); |
| expect(logger.statusText, contains(r''' |
| Added files: |
| - added.file |
| Modified files: |
| - pubspec.yaml |
| |
| All conflicts resolved. Review changes above and apply the migration with: |
| |
| $ flutter migrate apply |
| ''')); |
| |
| expect(logger.statusText, contains(r''' |
| @@ -1,5 +1,5 @@ |
| -name: originalname |
| -description: A new Flutter project. |
| +name: newname |
| +description: new description of the test project |
| version: 1.0.0+1 |
| environment: |
| sdk: '>=2.18.0-58.0.dev <3.0.0' |
| @@ -10,4 +10,5 @@ dev_dependencies: |
| flutter_test: |
| sdk: flutter |
| flutter: |
| - uses-material-design: true |
| \ No newline at end of file |
| + uses-material-design: false |
| + EXTRALINE''')); |
| |
| // Add conflict file |
| final File conflictFile = |
| stagingDir.childDirectory('conflict').childFile('conflict.file'); |
| conflictFile.createSync(recursive: true); |
| conflictFile.writeAsStringSync(''' |
| line1 |
| <<<<<<< /conflcit/conflict.file |
| line2 |
| ======= |
| linetwo |
| >>>>>>> /var/folders/md/gm0zgfcj07vcsj6jkh_mp_wh00ff02/T/flutter_tools.4Xdep8/generatedTargetTemplatetlN44S/conflict/conflict.file |
| line3 |
| ''', flush: true); |
| final File conflictFileOriginal = |
| appDir.childDirectory('conflict').childFile('conflict.file'); |
| conflictFileOriginal.createSync(recursive: true); |
| conflictFileOriginal.writeAsStringSync(''' |
| line1 |
| line2 |
| line3 |
| ''', flush: true); |
| |
| manifestFile.writeAsStringSync(''' |
| merged_files: |
| - pubspec.yaml |
| conflict_files: |
| - conflict/conflict.file |
| added_files: |
| - added.file |
| deleted_files: |
| '''); |
| |
| logger.clear(); |
| await createTestCommandRunner(command).run(<String>[ |
| 'status', |
| '--staging-directory=${stagingDir.path}', |
| '--project-directory=${appDir.path}', |
| '--flutter-subcommand', |
| ]); |
| |
| expect(logger.statusText, contains(''' |
| @@ -1,3 +1,7 @@ |
| line1 |
| +<<<<<<< /conflcit/conflict.file |
| line2 |
| +======= |
| +linetwo |
| +>>>>>>>''')); |
| }, overrides: <Type, Generator>{ |
| FileSystem: () => fileSystem, |
| ProcessManager: () => processManager, |
| }); |
| } |