mirror of
https://github.com/flutter/flutter
synced 2024-10-13 19:52:53 +00:00
1b4f817b0c
1. Add `PortScanner` abstraction so that we don't do actual port scanning in tests. 2. Don't change the real `cwd` of the isolate during tests, as it affects all tests, not just the current running test. Fixes #8761
50 lines
1.5 KiB
Dart
50 lines
1.5 KiB
Dart
// Copyright 2016 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.
|
|
|
|
import 'package:file/file.dart';
|
|
import 'package:file/memory.dart';
|
|
import 'package:flutter_tools/src/cache.dart';
|
|
import 'package:flutter_tools/src/commands/analyze_base.dart';
|
|
import 'package:test/test.dart';
|
|
|
|
import 'src/context.dart';
|
|
|
|
const String _kFlutterRoot = '/data/flutter';
|
|
|
|
void main() {
|
|
FileSystem fs;
|
|
Directory tempDir;
|
|
|
|
setUp(() {
|
|
fs = new MemoryFileSystem();
|
|
fs.directory(_kFlutterRoot).createSync(recursive: true);
|
|
Cache.flutterRoot = _kFlutterRoot;
|
|
tempDir = fs.systemTempDirectory.createTempSync('analysis_test');
|
|
});
|
|
|
|
group('analyze', () {
|
|
testUsingContext('inRepo', () {
|
|
// Absolute paths
|
|
expect(inRepo(<String>[tempDir.path]), isFalse);
|
|
expect(inRepo(<String>[fs.path.join(tempDir.path, 'foo')]), isFalse);
|
|
expect(inRepo(<String>[Cache.flutterRoot]), isTrue);
|
|
expect(inRepo(<String>[fs.path.join(Cache.flutterRoot, 'foo')]), isTrue);
|
|
|
|
// Relative paths
|
|
fs.currentDirectory = Cache.flutterRoot;
|
|
expect(inRepo(<String>['.']), isTrue);
|
|
expect(inRepo(<String>['foo']), isTrue);
|
|
fs.currentDirectory = tempDir.path;
|
|
expect(inRepo(<String>['.']), isFalse);
|
|
expect(inRepo(<String>['foo']), isFalse);
|
|
|
|
// Ensure no exceptions
|
|
inRepo(null);
|
|
inRepo(<String>[]);
|
|
}, overrides: <Type, Generator>{
|
|
FileSystem: () => fs,
|
|
});
|
|
});
|
|
}
|