blob: 3fcdde09e09e26a26a8c3bf987f6fafc98caf47a [file] [log] [blame]
// 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 'dart:async';
import 'package:args/command_runner.dart';
import 'package:flutter_tools/src/base/file_system.dart';
import 'package:flutter_tools/src/base/io.dart';
import 'package:flutter_tools/src/cache.dart';
import 'package:flutter_tools/src/commands/packages.dart';
import 'package:process/process.dart';
import 'package:test/test.dart';
import '../src/common.dart';
import '../src/context.dart';
void main() {
Cache.disableLocking();
group('packages get/upgrade', () {
Directory temp;
setUp(() {
temp = fs.systemTempDirectory.createTempSync('flutter_tools');
});
tearDown(() {
temp.deleteSync(recursive: true);
});
Future<String> runCommand(String verb, { List<String> args }) async {
final String projectPath = await createProject(temp);
final PackagesCommand command = new PackagesCommand();
final CommandRunner<Null> runner = createTestCommandRunner(command);
final List<String> commandArgs = <String>['packages', verb];
if (args != null)
commandArgs.addAll(args);
commandArgs.add(projectPath);
await runner.run(commandArgs);
return projectPath;
}
void expectExists(String projectPath, String relPath) {
expect(fs.isFileSync(fs.path.join(projectPath, relPath)), true);
}
// Verify that we create a project that is well-formed.
testUsingContext('get', () async {
final String projectPath = await runCommand('get');
expectExists(projectPath, 'lib/main.dart');
expectExists(projectPath, '.packages');
});
testUsingContext('get --offline', () async {
final String projectPath = await runCommand('get', args: <String>['--offline']);
expectExists(projectPath, 'lib/main.dart');
expectExists(projectPath, '.packages');
});
testUsingContext('upgrade', () async {
final String projectPath = await runCommand('upgrade');
expectExists(projectPath, 'lib/main.dart');
expectExists(projectPath, '.packages');
});
});
group('packages test/pub', () {
final List<List<dynamic>> log = <List<dynamic>>[];
testUsingContext('test', () async {
log.clear();
await createTestCommandRunner(new PackagesCommand()).run(<String>['packages', 'test']);
expect(log, hasLength(1));
expect(log[0], hasLength(3));
expect(log[0][0], matches(r'dart-sdk[\\/]bin[\\/]pub'));
expect(log[0][1], 'run');
expect(log[0][2], 'test');
}, overrides: <Type, Generator>{
ProcessManager: () {
return new MockProcessManager((List<dynamic> command) {
log.add(command);
});
},
});
testUsingContext('run', () async {
log.clear();
await createTestCommandRunner(new PackagesCommand()).run(<String>['packages', '--verbose', 'pub', 'run', '--foo', 'bar']);
expect(log, hasLength(1));
expect(log[0], hasLength(4));
expect(log[0][0], matches(r'dart-sdk[\\/]bin[\\/]pub'));
expect(log[0][1], 'run');
expect(log[0][2], '--foo');
expect(log[0][3], 'bar');
}, overrides: <Type, Generator>{
ProcessManager: () {
return new MockProcessManager((List<dynamic> command) {
log.add(command);
});
},
});
});
}
typedef void StartCallback(List<dynamic> command);
class MockProcessManager implements ProcessManager {
MockProcessManager(this.onStart);
final StartCallback onStart;
@override
Future<Process> start(
List<dynamic> command, {
String workingDirectory,
Map<String, String> environment,
bool includeParentEnvironment: true,
bool runInShell: false,
ProcessStartMode mode: ProcessStartMode.NORMAL,
}) {
onStart(command);
return new Future<Process>.value(new MockProcess());
}
@override
dynamic noSuchMethod(Invocation invocation) => null;
}
class MockProcess implements Process {
@override
Stream<List<int>> get stdout => new MockStream<List<int>>();
@override
Stream<List<int>> get stderr => new MockStream<List<int>>();
@override
Future<int> get exitCode => new Future<int>.value(0);
@override
dynamic noSuchMethod(Invocation invocation) => null;
}
class MockStream<T> implements Stream<T> {
@override
Stream<S> transform<S>(StreamTransformer<T, S> streamTransformer) => new MockStream<S>();
@override
Stream<T> where(bool test(T event)) => new MockStream<T>();
@override
StreamSubscription<T> listen(void onData(T event), {Function onError, void onDone(), bool cancelOnError}) {
return new MockStreamSubscription<T>();
}
@override
dynamic noSuchMethod(Invocation invocation) => null;
}
class MockStreamSubscription<T> implements StreamSubscription<T> {
@override
Future<E> asFuture<E>([E futureValue]) => new Future<E>.value();
@override
Future<Null> cancel() => null;
@override
dynamic noSuchMethod(Invocation invocation) => null;
}