blob: d47b9501fa52248b026f38fa236a50aa56189116 [file] [log] [blame]
// Copyright (c) 2014, the Dart project authors. Please see the AUTHORS file
// for details. 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:scheduled_test/scheduled_test.dart';
import '../descriptor.dart' as d;
import '../test_pub.dart';
import 'utils.dart';
const SCRIPT = """
import "package:myapp/lib.dart";
main() {
callLib();
}
""";
const LIB = """
callLib() {
print("lib");
}
""";
// Make it lazy so that "lib.dart" isn't transformed until after the process
// is started. Otherwise, since this tranformer modifies .dart files, it will
// be run while the transformers themselves are loading during pub run's
// startup.
const TRANSFORMER = """
import 'dart:async';
import 'package:barback/barback.dart';
class LoggingTransformer extends Transformer implements LazyTransformer {
LoggingTransformer.asPlugin();
String get allowedExtensions => '.dart';
void apply(Transform transform) {
transform.logger.info('\${transform.primaryInput.id}.');
transform.logger.warning('\${transform.primaryInput.id}.');
}
void declareOutputs(DeclaringTransform transform) {
// TODO(rnystrom): Remove this when #19408 is fixed.
transform.declareOutput(transform.primaryId);
}
}
""";
main() {
initConfig();
withBarbackVersions("any", () {
integration('displays transformer log messages', () {
d.dir(appPath, [
d.pubspec({
"name": "myapp",
"transformers": ["myapp/src/transformer"]
}),
d.dir("lib", [
d.file("lib.dart", LIB),
d.dir("src", [
d.file("transformer.dart", TRANSFORMER)
])
]),
d.dir("bin", [
d.file("script.dart", SCRIPT)
])
]).create();
createLockFile('myapp', pkg: ['barback']);
var pub = pubRun(args: ["script"],
transformers: ["myapp/src/transformer"]);
// Note that the info log is only displayed here because the test
// harness runs pub in verbose mode. By default, only the warning would
// be shown.
pub.stdout.expect("[Info from Logging]:");
pub.stdout.expect("myapp|bin/script.dart.");
pub.stderr.expect("[Warning from Logging]:");
pub.stderr.expect("myapp|bin/script.dart.");
pub.stdout.expect("[Info from Logging]:");
pub.stdout.expect("myapp|lib/lib.dart.");
pub.stderr.expect("[Warning from Logging]:");
pub.stderr.expect("myapp|lib/lib.dart.");
pub.stdout.expect("lib");
pub.shouldExit();
});
});
}