| Index: test/codegen/lib/convert/utf83_test.dart | 
| diff --git a/test/codegen/lib/convert/utf83_test.dart b/test/codegen/lib/convert/utf83_test.dart | 
| new file mode 100644 | 
| index 0000000000000000000000000000000000000000..093d5a9fa9a7b8a14fb98ca5b8ac96cc95238bdf | 
| --- /dev/null | 
| +++ b/test/codegen/lib/convert/utf83_test.dart | 
| @@ -0,0 +1,45 @@ | 
| +// Copyright (c) 2012, 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 utf8_test; | 
| +import "package:expect/expect.dart"; | 
| +import 'dart:convert'; | 
| + | 
| +main() { | 
| +  // Test that UTF8-decoder removes leading BOM. | 
| +  Expect.equals("a", UTF8.decode([0xEF, 0xBB, 0xBF, 0x61])); | 
| +  Expect.equals("a", UTF8.decoder.convert([0xEF, 0xBB, 0xBF, 0x61])); | 
| +  Expect.equals("a", new Utf8Decoder().convert([0xEF, 0xBB, 0xBF, 0x61])); | 
| +  Expect.equals("a", | 
| +                UTF8.decode([0xEF, 0xBB, 0xBF, 0x61], allowMalformed: true)); | 
| +  Expect.equals("a", new Utf8Codec(allowMalformed: true) | 
| +                         .decode([0xEF, 0xBB, 0xBF, 0x61])); | 
| +  Expect.equals("a", new Utf8Codec(allowMalformed: true) | 
| +                         .decoder.convert([0xEF, 0xBB, 0xBF, 0x61])); | 
| +  Expect.equals("a", new Utf8Decoder(allowMalformed: true) | 
| +                         .convert([0xEF, 0xBB, 0xBF, 0x61])); | 
| +  Expect.equals("", UTF8.decode([0xEF, 0xBB, 0xBF])); | 
| +  Expect.equals("", UTF8.decoder.convert([0xEF, 0xBB, 0xBF])); | 
| +  Expect.equals("", new Utf8Decoder().convert([0xEF, 0xBB, 0xBF])); | 
| +  Expect.equals("", | 
| +                UTF8.decode([0xEF, 0xBB, 0xBF], allowMalformed: true)); | 
| +  Expect.equals("", new Utf8Codec(allowMalformed: true) | 
| +                         .decode([0xEF, 0xBB, 0xBF])); | 
| +  Expect.equals("", new Utf8Codec(allowMalformed: true) | 
| +                         .decoder.convert([0xEF, 0xBB, 0xBF])); | 
| +  Expect.equals("", new Utf8Decoder(allowMalformed: true) | 
| +                         .convert([0xEF, 0xBB, 0xBF])); | 
| +  Expect.equals("a\u{FEFF}", UTF8.decode([0x61, 0xEF, 0xBB, 0xBF])); | 
| +  Expect.equals("a\u{FEFF}", UTF8.decoder.convert([0x61, 0xEF, 0xBB, 0xBF])); | 
| +  Expect.equals("a\u{FEFF}", | 
| +                new Utf8Decoder().convert([0x61, 0xEF, 0xBB, 0xBF])); | 
| +  Expect.equals("a\u{FEFF}", | 
| +                UTF8.decode([0x61, 0xEF, 0xBB, 0xBF], allowMalformed: true)); | 
| +  Expect.equals("a\u{FEFF}", new Utf8Codec(allowMalformed: true) | 
| +                         .decode([0x61, 0xEF, 0xBB, 0xBF])); | 
| +  Expect.equals("a\u{FEFF}", new Utf8Codec(allowMalformed: true) | 
| +                         .decoder.convert([0x61, 0xEF, 0xBB, 0xBF])); | 
| +  Expect.equals("a\u{FEFF}", new Utf8Decoder(allowMalformed: true) | 
| +                         .convert([0x61, 0xEF, 0xBB, 0xBF])); | 
| +} | 
|  |