clean_test.dart 4.98 KB
Newer Older
1 2 3 4
// Copyright 2019 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

5
import 'package:file/memory.dart';
6 7
import 'package:flutter_tools/src/base/context.dart';
import 'package:flutter_tools/src/base/file_system.dart';
8 9
import 'package:flutter_tools/src/base/logger.dart';
import 'package:flutter_tools/src/base/platform.dart';
10
import 'package:flutter_tools/src/commands/clean.dart';
11 12 13
import 'package:flutter_tools/src/ios/xcodeproj.dart';
import 'package:flutter_tools/src/macos/xcode.dart';
import 'package:flutter_tools/src/project.dart';
14
import 'package:mockito/mockito.dart';
15
import 'package:process/process.dart';
16

17 18
import '../../src/common.dart';
import '../../src/context.dart';
19 20

void main() {
21 22 23 24
  void test1() {
    final MemoryFileSystem fs = MemoryFileSystem();
    final MockXcodeProjectInterpreter mockXcodeProjectInterpreter = MockXcodeProjectInterpreter();
    final MockXcode mockXcode = MockXcode();
25 26

    final Directory currentDirectory = fs.currentDirectory;
27
    final Directory buildDirectory = currentDirectory.childDirectory('build');
28 29
    buildDirectory.createSync(recursive: true);

30
    final FlutterProject projectUnderTest = FlutterProject.fromDirectory(currentDirectory);
31 32 33 34 35 36
    projectUnderTest.ios.xcodeWorkspace.createSync(recursive: true);
    projectUnderTest.macos.xcodeWorkspace.createSync(recursive: true);

    projectUnderTest.dartTool.createSync(recursive: true);
    projectUnderTest.android.ephemeralDirectory.createSync(recursive: true);
    projectUnderTest.ios.ephemeralDirectory.createSync(recursive: true);
37
    projectUnderTest.linux.ephemeralDirectory.createSync(recursive: true);
38
    projectUnderTest.macos.ephemeralDirectory.createSync(recursive: true);
39
    projectUnderTest.windows.ephemeralDirectory.createSync(recursive: true);
40

41
    testUsingContext('$CleanCommand removes build and .dart_tool and ephemeral directories, cleans Xcode', () async {
42
      when(mockXcode.isInstalledAndMeetsVersionCheck).thenReturn(true);
43
      await CleanCommand().runCommand();
44 45 46 47 48

      expect(buildDirectory.existsSync(), isFalse);
      expect(projectUnderTest.dartTool.existsSync(), isFalse);
      expect(projectUnderTest.android.ephemeralDirectory.existsSync(), isFalse);
      expect(projectUnderTest.ios.ephemeralDirectory.existsSync(), isFalse);
49
      expect(projectUnderTest.linux.ephemeralDirectory.existsSync(), isFalse);
50
      expect(projectUnderTest.macos.ephemeralDirectory.existsSync(), isFalse);
51
      expect(projectUnderTest.windows.ephemeralDirectory.existsSync(), isFalse);
52 53

      verify(xcodeProjectInterpreter.cleanWorkspace(any, 'Runner')).called(2);
54
    }, overrides: <Type, Generator>{
55
      FileSystem: () => fs,
56
      ProcessManager: () => FakeProcessManager.any(),
57 58
      Xcode: () => mockXcode,
      XcodeProjectInterpreter: () => mockXcodeProjectInterpreter,
59
    });
60
  }
61

62 63 64 65
  void test2() {
    final MockXcode mockXcode = MockXcode();
    final MockPlatform windowsPlatform = MockPlatform();
    testUsingContext('$CleanCommand prints a helpful error message on Windows', () async {
66 67 68 69 70 71
      when(mockXcode.isInstalledAndMeetsVersionCheck).thenReturn(false);
      when(windowsPlatform.isWindows).thenReturn(true);

      final MockFile mockFile = MockFile();
      when(mockFile.existsSync()).thenReturn(true);

72
      final BufferLogger logger = context.get<Logger>();
73 74 75
      when(mockFile.deleteSync(recursive: true)).thenThrow(const FileSystemException('Deletion failed'));
      final CleanCommand command = CleanCommand();
      command.deleteFile(mockFile);
76
      expect(logger.errorText, contains('A program may still be using a file'));
77
      verify(mockFile.deleteSync(recursive: true)).called(1);
78 79 80
    }, overrides: <Type, Generator>{
      Platform: () => windowsPlatform,
      Logger: () => BufferLogger(),
81
      Xcode: () => mockXcode,
82
    });
83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100

    testUsingContext('$CleanCommand handles missing permissions;', () async {
      when(mockXcode.isInstalledAndMeetsVersionCheck).thenReturn(false);

      final MockFile mockFile = MockFile();
      when(mockFile.existsSync()).thenThrow(const FileSystemException('OS error: Access Denied'));
      when(mockFile.path).thenReturn('foo.dart');

      final BufferLogger logger = context.get<Logger>();
      final CleanCommand command = CleanCommand();
      command.deleteFile(mockFile);
      expect(logger.errorText, contains('Cannot clean foo.dart'));
      verifyNever(mockFile.deleteSync(recursive: true));
    }, overrides: <Type, Generator>{
      Platform: () => windowsPlatform,
      Logger: () => BufferLogger(),
      Xcode: () => mockXcode,
    });
101 102 103 104
  }

  test1();
  test2();
105 106 107
}

class MockFile extends Mock implements File {}
108
class MockPlatform extends Mock implements Platform {}
109 110 111 112
class MockXcode extends Mock implements Xcode {}

class MockXcodeProjectInterpreter extends Mock implements XcodeProjectInterpreter {
  @override
113
  Future<XcodeProjectInfo> getInfo(String projectPath, {String projectFilename}) async {
114 115 116
    return XcodeProjectInfo(null, null, <String>['Runner']);
  }
}