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())); |
+} |