backend v4 half
This commit is contained in:
Generated
Vendored
+65
@@ -0,0 +1,65 @@
|
||||
import parseIncompletePhoneNumber, { parsePhoneNumberCharacter } from './parseIncompletePhoneNumber.js';
|
||||
describe('parseIncompletePhoneNumber', function () {
|
||||
it('should parse phone number character', function () {
|
||||
// Accepts leading `+`.
|
||||
parsePhoneNumberCharacter('+').should.equal('+'); // Doesn't accept non-leading `+`.
|
||||
|
||||
expect(parsePhoneNumberCharacter('+', '+')).to.be.undefined; // Parses digits.
|
||||
|
||||
parsePhoneNumberCharacter('1').should.equal('1'); // Parses non-European digits.
|
||||
|
||||
parsePhoneNumberCharacter('٤').should.equal('4'); // Dismisses other characters.
|
||||
|
||||
expect(parsePhoneNumberCharacter('-')).to.be.undefined;
|
||||
});
|
||||
it('should parse incomplete phone number', function () {
|
||||
parseIncompletePhoneNumber('').should.equal(''); // Doesn't accept non-leading `+`.
|
||||
|
||||
parseIncompletePhoneNumber('++').should.equal('+'); // Accepts leading `+`.
|
||||
|
||||
parseIncompletePhoneNumber('+7 800 555').should.equal('+7800555'); // Parses digits.
|
||||
|
||||
parseIncompletePhoneNumber('8 (800) 555').should.equal('8800555'); // Parses non-European digits.
|
||||
|
||||
parseIncompletePhoneNumber('+٤٤٢٣٢٣٢٣٤').should.equal('+442323234');
|
||||
});
|
||||
it('should work with a new `context` argument in `parsePhoneNumberCharacter()` function (international number)', function () {
|
||||
var stopped = false;
|
||||
|
||||
var emit = function emit(event) {
|
||||
switch (event) {
|
||||
case 'end':
|
||||
stopped = true;
|
||||
break;
|
||||
}
|
||||
};
|
||||
|
||||
parsePhoneNumberCharacter('+', undefined, emit).should.equal('+');
|
||||
expect(stopped).to.equal(false);
|
||||
parsePhoneNumberCharacter('1', '+', emit).should.equal('1');
|
||||
expect(stopped).to.equal(false);
|
||||
expect(parsePhoneNumberCharacter('+', '+1', emit)).to.equal(undefined);
|
||||
expect(stopped).to.equal(true);
|
||||
expect(parsePhoneNumberCharacter('2', '+1', emit)).to.equal('2');
|
||||
expect(stopped).to.equal(true);
|
||||
});
|
||||
it('should work with a new `context` argument in `parsePhoneNumberCharacter()` function (national number)', function () {
|
||||
var stopped = false;
|
||||
|
||||
var emit = function emit(event) {
|
||||
switch (event) {
|
||||
case 'end':
|
||||
stopped = true;
|
||||
break;
|
||||
}
|
||||
};
|
||||
|
||||
parsePhoneNumberCharacter('2', undefined, emit).should.equal('2');
|
||||
expect(stopped).to.equal(false);
|
||||
expect(parsePhoneNumberCharacter('+', '2', emit)).to.equal(undefined);
|
||||
expect(stopped).to.equal(true);
|
||||
expect(parsePhoneNumberCharacter('1', '2', emit)).to.equal('1');
|
||||
expect(stopped).to.equal(true);
|
||||
});
|
||||
});
|
||||
//# sourceMappingURL=parseIncompletePhoneNumber.test.js.map
|
||||
Reference in New Issue
Block a user