| Index: packages/barback/test/asset_test.dart
|
| diff --git a/packages/barback/test/asset_test.dart b/packages/barback/test/asset_test.dart
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..7936c71fc194e1a59467b2bde4399fb07e0032cf
|
| --- /dev/null
|
| +++ b/packages/barback/test/asset_test.dart
|
| @@ -0,0 +1,268 @@
|
| +// Copyright (c) 2013, 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.
|
| +
|
| +library barback.test.asset_test;
|
| +
|
| +import 'dart:async';
|
| +import 'dart:convert';
|
| +import 'dart:io';
|
| +import 'dart:isolate';
|
| +
|
| +import 'package:barback/barback.dart';
|
| +import 'package:barback/src/asset/internal_asset.dart';
|
| +import 'package:path/path.dart' as pathos;
|
| +import 'package:unittest/unittest.dart';
|
| +
|
| +import 'utils.dart';
|
| +
|
| +/// The contents of the test binary file.
|
| +final binaryContents = [0, 1, 2, 3, 4];
|
| +
|
| +main() {
|
| + initConfig();
|
| +
|
| + Directory tempDir;
|
| + String binaryFilePath;
|
| + String textFilePath;
|
| + String latin1FilePath;
|
| +
|
| + setUp(() {
|
| + // Create a temp file we can use for assets.
|
| + tempDir = Directory.systemTemp.createTempSync('barback_asset_test_');
|
| + binaryFilePath = pathos.join(tempDir.path, "file.bin");
|
| + new File(binaryFilePath).writeAsBytesSync(binaryContents);
|
| +
|
| + textFilePath = pathos.join(tempDir.path, "file.txt");
|
| + new File(textFilePath).writeAsStringSync("çøñ†éℵ™");
|
| +
|
| + latin1FilePath = pathos.join(tempDir.path, "file.latin1");
|
| + new File(latin1FilePath).writeAsBytesSync(LATIN1.encode("blåbærgrød"));
|
| + });
|
| +
|
| + tearDown(() {
|
| + if (tempDir != null) tempDir.deleteSync(recursive: true);
|
| + });
|
| +
|
| + var id = new AssetId.parse("package|path/to/asset.txt");
|
| +
|
| + group("Asset.fromBytes", () {
|
| + test("returns an asset with the given ID", () {
|
| + var asset = new Asset.fromBytes(id, [1]);
|
| + expect(asset.id, equals(id));
|
| + });
|
| + });
|
| +
|
| + group("Asset.fromFile", () {
|
| + test("returns an asset with the given ID", () {
|
| + var asset = new Asset.fromFile(id, new File("asset.txt"));
|
| + expect(asset.id, equals(id));
|
| + });
|
| + });
|
| +
|
| + group("Asset.fromPath", () {
|
| + test("returns an asset with the given ID", () {
|
| + var asset = new Asset.fromPath(id, "asset.txt");
|
| + expect(asset.id, equals(id));
|
| + });
|
| + });
|
| +
|
| + group("Asset.fromString", () {
|
| + test("returns an asset with the given ID", () {
|
| + var asset = new Asset.fromString(id, "content");
|
| + expect(asset.id, equals(id));
|
| + });
|
| + });
|
| +
|
| + group("Asset.fromStream", () {
|
| + test("returns an asset with the given ID", () {
|
| + var asset = new Asset.fromStream(id,
|
| + new Stream.fromFuture(new Future.value([104, 101, 108, 108, 111])));
|
| + expect(asset.id, equals(id));
|
| + });
|
| + });
|
| +
|
| + group("read()", () {
|
| + test("gets the UTF-8-encoded string for a string asset", () {
|
| + var asset = new Asset.fromString(id, "çøñ†éℵ™");
|
| + expect(asset.read().toList(),
|
| + completion(equals([UTF8.encode("çøñ†éℵ™")])));
|
| + });
|
| +
|
| + test("gets the raw bytes for a byte asset", () {
|
| + var asset = new Asset.fromBytes(id, binaryContents);
|
| + expect(asset.read().toList(),
|
| + completion(equals([binaryContents])));
|
| + });
|
| +
|
| + test("gets the raw bytes for a binary file", () {
|
| + var asset = new Asset.fromPath(id, binaryFilePath);
|
| + expect(asset.read().toList(),
|
| + completion(equals([binaryContents])));
|
| + });
|
| +
|
| + test("gets the raw bytes for a text file", () {
|
| + var asset = new Asset.fromPath(id, textFilePath);
|
| + expect(asset.read().toList(),
|
| + completion(equals([UTF8.encode("çøñ†éℵ™")])));
|
| + });
|
| +
|
| + test("gets the raw bytes for a stream", () {
|
| + var asset = new Asset.fromStream(id,
|
| + new Stream.fromFuture(new Future.value(UTF8.encode("çøñ†éℵ™"))));
|
| + expect(asset.read().toList(),
|
| + completion(equals([UTF8.encode("çøñ†éℵ™")])));
|
| + });
|
| + });
|
| +
|
| + group("readAsString()", () {
|
| + group("byte asset", () {
|
| + test("defaults to UTF-8 if encoding is omitted", () {
|
| + var asset = new Asset.fromBytes(id, UTF8.encode("çøñ†éℵ™"));
|
| + expect(asset.readAsString(),
|
| + completion(equals("çøñ†éℵ™")));
|
| + });
|
| +
|
| + test("supports UTF-8", () {
|
| + var asset = new Asset.fromBytes(id, UTF8.encode("çøñ†éℵ™"));
|
| + expect(asset.readAsString(encoding: UTF8),
|
| + completion(equals("çøñ†éℵ™")));
|
| + });
|
| +
|
| + // TODO(rnystrom): Test other encodings once #6284 is fixed.
|
| + });
|
| +
|
| + group("string asset", () {
|
| + test("gets the string", () {
|
| + var asset = new Asset.fromString(id, "contents");
|
| + expect(asset.readAsString(),
|
| + completion(equals("contents")));
|
| + });
|
| +
|
| + test("ignores the encoding", () {
|
| + var asset = new Asset.fromString(id, "contents");
|
| + expect(asset.readAsString(encoding: LATIN1),
|
| + completion(equals("contents")));
|
| + });
|
| + });
|
| +
|
| + group("file asset", () {
|
| + test("defaults to UTF-8 if encoding is omitted", () {
|
| + var asset = new Asset.fromPath(id, textFilePath);
|
| + expect(asset.readAsString(),
|
| + completion(equals("çøñ†éℵ™")));
|
| + });
|
| + });
|
| +
|
| + group("stream asset", () {
|
| + test("defaults to UTF-8 if encoding is omitted", () {
|
| + var asset = new Asset.fromStream(id,
|
| + new Stream.fromFuture(new Future.value(UTF8.encode("çøñ†éℵ™"))));
|
| + expect(asset.readAsString(),
|
| + completion(equals("çøñ†éℵ™")));
|
| + });
|
| +
|
| + test("supports UTF-8", () {
|
| + var asset = new Asset.fromStream(id,
|
| + new Stream.fromFuture(new Future.value(UTF8.encode("çøñ†éℵ™"))));
|
| + expect(asset.readAsString(encoding: UTF8),
|
| + completion(equals("çøñ†éℵ™")));
|
| + });
|
| +
|
| + test("supports ISO-8859-1", () {
|
| + var future = new Future.value(LATIN1.encode("blåbærgrød"));
|
| + var asset = new Asset.fromStream(id, new Stream.fromFuture(future));
|
| + expect(asset.readAsString(encoding: LATIN1),
|
| + completion(equals("blåbærgrød")));
|
| + });
|
| + });
|
| + });
|
| +
|
| + group("toString()", () {
|
| + group("byte asset", () {
|
| + test("shows the list of bytes in hex", () {
|
| + var asset = new Asset.fromBytes(id,
|
| + [0, 1, 2, 4, 8, 16, 32, 64, 128, 255]);
|
| + expect(asset.toString(), equals(
|
| + "Bytes [00 01 02 04 08 10 20 40 80 ff]"));
|
| + });
|
| +
|
| + test("truncates the middle of there are more than ten bytes", () {
|
| + var asset = new Asset.fromBytes(id,
|
| + [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14]);
|
| + expect(asset.toString(), equals(
|
| + "Bytes [01 02 03 04 05 ... 0a 0b 0c 0d 0e]"));
|
| + });
|
| + });
|
| +
|
| + group("string asset", () {
|
| + test("shows the contents", () {
|
| + var asset = new Asset.fromString(id, "contents");
|
| + expect(asset.toString(), equals(
|
| + 'String "contents"'));
|
| + });
|
| +
|
| + test("truncates the middle of there are more than 40 characters", () {
|
| + var asset = new Asset.fromString(id,
|
| + "this is a fairly long string asset content that gets shortened");
|
| + expect(asset.toString(), equals(
|
| + 'String "this is a fairly lon ... that gets shortened"'));
|
| + });
|
| + });
|
| +
|
| + group("file asset", () {
|
| + test("shows the file path", () {
|
| + var asset = new Asset.fromPath(id, "path.txt");
|
| + expect(asset.toString(), equals('File "path.txt"'));
|
| + });
|
| + });
|
| + });
|
| +
|
| + group("across isolates", () {
|
| + getBytesFromIsolate(Asset asset) {
|
| + var port = new ReceivePort();
|
| + return Isolate.spawn(_getAssetBytes, {
|
| + 'asset': serializeAsset(asset),
|
| + 'replyTo': port.sendPort
|
| + }).then((_) => port.first);
|
| + }
|
| +
|
| + test("gets the UTF-8-encoded string for a string asset", () {
|
| + var asset = new Asset.fromString(id, "çøñ†éℵ™");
|
| + expect(getBytesFromIsolate(asset),
|
| + completion(equals(UTF8.encode("çøñ†éℵ™"))));
|
| + });
|
| +
|
| + test("gets the raw bytes for a byte asset", () {
|
| + var asset = new Asset.fromBytes(id, binaryContents);
|
| + expect(getBytesFromIsolate(asset),
|
| + completion(equals(binaryContents)));
|
| + });
|
| +
|
| + test("gets the raw bytes for a binary file", () {
|
| + var asset = new Asset.fromPath(id, binaryFilePath);
|
| + expect(getBytesFromIsolate(asset),
|
| + completion(equals(binaryContents)));
|
| + });
|
| +
|
| + test("gets the raw bytes for a text file", () {
|
| + var asset = new Asset.fromPath(id, textFilePath);
|
| + expect(getBytesFromIsolate(asset),
|
| + completion(equals(UTF8.encode("çøñ†éℵ™"))));
|
| + });
|
| +
|
| + test("gets the raw bytes for a stream", () {
|
| + var asset = new Asset.fromStream(id,
|
| + new Stream.fromFuture(new Future.value(UTF8.encode("çøñ†éℵ™"))));
|
| + expect(getBytesFromIsolate(asset),
|
| + completion(equals(UTF8.encode("çøñ†éℵ™"))));
|
| + });
|
| + });
|
| +}
|
| +
|
| +void _getAssetBytes(message) {
|
| + var asset = deserializeAsset(message['asset']);
|
| + var builder = asset.read().fold(new BytesBuilder(),
|
| + (builder, chunk) => builder..add(chunk));
|
| + builder.then((builder) => message['replyTo'].send(builder.takeBytes()));
|
| +}
|
|
|