mirror of
https://github.com/servo/servo.git
synced 2025-06-23 16:44:33 +01:00
36 lines
1.5 KiB
HTML
36 lines
1.5 KiB
HTML
<!DOCTYPE html>
|
|
<title>Encoding API: Encoding labels</title>
|
|
<script src="/resources/testharness.js"></script>
|
|
<script src="/resources/testharnessreport.js"></script>
|
|
<script src="resources/encodings.js"></script>
|
|
<script>
|
|
var whitespace = [' ', '\t', '\n', '\f', '\r'];
|
|
encodings_table.forEach(function(section) {
|
|
section.encodings.filter(function(encoding) {
|
|
return encoding.name !== 'replacement';
|
|
}).forEach(function(encoding) {
|
|
encoding.labels.forEach(function(label) {
|
|
const textDecoderName = encoding.name.toLowerCase(); // ASCII names only, so safe
|
|
test(function(t) {
|
|
assert_equals(
|
|
new TextDecoder(label).encoding, textDecoderName,
|
|
'label for encoding should match');
|
|
assert_equals(
|
|
new TextDecoder(label.toUpperCase()).encoding, textDecoderName,
|
|
'label matching should be case-insensitive');
|
|
whitespace.forEach(function(ws) {
|
|
assert_equals(
|
|
new TextDecoder(ws + label).encoding, textDecoderName,
|
|
'label for encoding with leading whitespace should match');
|
|
assert_equals(
|
|
new TextDecoder(label + ws).encoding, textDecoderName,
|
|
'label for encoding with trailing whitespace should match');
|
|
assert_equals(
|
|
new TextDecoder(ws + label + ws).encoding, textDecoderName,
|
|
'label for encoding with surrounding whitespace should match');
|
|
});
|
|
}, label + ' => ' + encoding.name);
|
|
});
|
|
});
|
|
});
|
|
</script>
|