/* Copyright 2017 Mozilla Foundation * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ 'use strict'; var _glyphlist = require('../../core/glyphlist'); var _unicode = require('../../core/unicode'); describe('unicode', function () { describe('mapSpecialUnicodeValues', function () { it('should not re-map normal Unicode values', function () { expect((0, _unicode.mapSpecialUnicodeValues)(0x0041)).toEqual(0x0041); expect((0, _unicode.mapSpecialUnicodeValues)(0xFB01)).toEqual(0xFB01); }); it('should re-map special Unicode values', function () { expect((0, _unicode.mapSpecialUnicodeValues)(0xF8E9)).toEqual(0x00A9); expect((0, _unicode.mapSpecialUnicodeValues)(0xFFFF)).toEqual(0); }); }); describe('getUnicodeForGlyph', function () { var standardMap, dingbatsMap; beforeAll(function (done) { standardMap = (0, _glyphlist.getGlyphsUnicode)(); dingbatsMap = (0, _glyphlist.getDingbatsGlyphsUnicode)(); done(); }); afterAll(function () { standardMap = dingbatsMap = null; }); it('should get Unicode values for valid glyph names', function () { expect((0, _unicode.getUnicodeForGlyph)('A', standardMap)).toEqual(0x0041); expect((0, _unicode.getUnicodeForGlyph)('a1', dingbatsMap)).toEqual(0x2701); }); it('should recover Unicode values from uniXXXX/uXXXX{XX} glyph names', function () { expect((0, _unicode.getUnicodeForGlyph)('uni0041', standardMap)).toEqual(0x0041); expect((0, _unicode.getUnicodeForGlyph)('u0041', standardMap)).toEqual(0x0041); expect((0, _unicode.getUnicodeForGlyph)('uni2701', dingbatsMap)).toEqual(0x2701); expect((0, _unicode.getUnicodeForGlyph)('u2701', dingbatsMap)).toEqual(0x2701); }); it('should not get Unicode values for invalid glyph names', function () { expect((0, _unicode.getUnicodeForGlyph)('Qwerty', standardMap)).toEqual(-1); expect((0, _unicode.getUnicodeForGlyph)('Qwerty', dingbatsMap)).toEqual(-1); }); }); describe('getUnicodeRangeFor', function () { it('should get correct Unicode range', function () { expect((0, _unicode.getUnicodeRangeFor)(0x0041)).toEqual(0); expect((0, _unicode.getUnicodeRangeFor)(0xFB01)).toEqual(62); }); it('should not get a Unicode range', function () { expect((0, _unicode.getUnicodeRangeFor)(0x05FF)).toEqual(-1); }); }); describe('getNormalizedUnicodes', function () { var NormalizedUnicodes; beforeAll(function (done) { NormalizedUnicodes = (0, _unicode.getNormalizedUnicodes)(); done(); }); afterAll(function () { NormalizedUnicodes = null; }); it('should get normalized Unicode values for ligatures', function () { expect(NormalizedUnicodes['\uFB01']).toEqual('fi'); expect(NormalizedUnicodes['\u0675']).toEqual('\u0627\u0674'); }); it('should not normalize standard characters', function () { expect(NormalizedUnicodes['A']).toEqual(undefined); }); }); describe('reverseIfRtl', function () { var NormalizedUnicodes; function getGlyphUnicode(char) { if (NormalizedUnicodes[char] !== undefined) { return NormalizedUnicodes[char]; } return char; } beforeAll(function (done) { NormalizedUnicodes = (0, _unicode.getNormalizedUnicodes)(); done(); }); afterAll(function () { NormalizedUnicodes = null; }); it('should not reverse LTR characters', function () { var A = getGlyphUnicode('A'); expect((0, _unicode.reverseIfRtl)(A)).toEqual('A'); var fi = getGlyphUnicode('\uFB01'); expect((0, _unicode.reverseIfRtl)(fi)).toEqual('fi'); }); it('should reverse RTL characters', function () { var heAlef = getGlyphUnicode('\u05D0'); expect((0, _unicode.reverseIfRtl)(heAlef)).toEqual('\u05D0'); var arAlef = getGlyphUnicode('\u0675'); expect((0, _unicode.reverseIfRtl)(arAlef)).toEqual('\u0674\u0627'); }); }); });