Current File : /home/tradevaly/www/node_modules/chance/test/test.address.js |
import test from 'ava'
import Chance from '../chance.js'
import _ from 'lodash'
import phoneNumber from './helpers/phoneNumber.min.js'
const chance = new Chance()
// chance.address()
test('address() returns a string', t => {
t.true(_.isString(chance.address()))
})
test('address() starts with a number', t => {
_.times(1000, () => t.true(/[0-9]+.+/.test(chance.address())))
})
test('address() can take a short_suffix arg and obey it', t => {
_.times(1000, () => {
let address = chance.address({ short_suffix: true })
t.true(address.split(' ')[2].length < 5)
})
})
// chance.altitude()
test('altitude() looks right', t => {
t.is(typeof chance.altitude(), 'number')
})
test('altitude() is in the right range', t => {
_.times(1000, () => {
let altitude = chance.altitude()
t.true(altitude > 0)
t.true(altitude < 8848)
})
})
test('altitude() will accept a min and obey it', t => {
_.times(1000, () => {
let min = chance.floating({ min: 0, max: 8848 })
let altitude = chance.altitude({ min: min })
t.true(altitude > min)
t.true(altitude < 8848)
})
})
test('altitude() will accept a max and obey it', t => {
_.times(1000, () => {
let max = chance.floating({ min: 0, max: 8848 })
let altitude = chance.altitude({ max: max })
t.true(altitude > 0)
t.true(altitude < max)
})
})
// chance.areacode()
test('areacode() looks right', t => {
_.times(1000, () => {
let areacode = chance.areacode()
t.true(_.isString(areacode))
t.true(/^\(([2-9][0-8][0-9])\)$/.test(areacode))
})
})
test('areacode() can take parens', t => {
_.times(1000, () => {
let areacode = chance.areacode({ parens: false })
t.true(_.isString(areacode))
t.true(/^([2-9][0-8][0-9])$/.test(areacode))
})
})
// chance.city()
test('city() looks right', t => {
_.times(1000, () => {
let city = chance.city()
t.true(_.isString(city))
t.true(/[a-zA-Z]+/.test(city))
})
})
// chance.coordinates()
test('coordinates() looks right', t => {
_.times(1000, () => {
let coordinates = chance.coordinates()
t.true(_.isString(coordinates))
t.is(coordinates.split(',').length, 2)
})
})
test('coordinates() returns coordinates in DD format as default', t => {
_.times(1000, () => {
const CHARS_NOT_TO_CONTAIN = ['°', '’', '”']
let coordinates = chance.coordinates()
let [ latitude, longitude ] = coordinates.split(',')
t.true(_.isString(coordinates))
t.is(coordinates.split(',').length, 2)
t.true(CHARS_NOT_TO_CONTAIN.every(char => !latitude.includes(char)))
t.true(CHARS_NOT_TO_CONTAIN.every(char => !longitude.includes(char)))
})
})
test('coordinates() will obey DD format', t => {
_.times(1000, () => {
const CHARS_NOT_TO_CONTAIN = ['°', '’', '”']
let coordinates = chance.coordinates({format: 'dd'})
let [ latitude, longitude ] = coordinates.split(',')
t.true(_.isString(coordinates))
t.is(coordinates.split(',').length, 2)
t.true(CHARS_NOT_TO_CONTAIN.every(char => !latitude.includes(char)))
t.true(CHARS_NOT_TO_CONTAIN.every(char => !longitude.includes(char)))
})
})
test('coordinates() will obey DDM format', t => {
_.times(1000, () => {
const CHARS_TO_CONTAIN = ['°']
const CHARS_NOT_TO_CONTAIN = ['’', '”']
let coordinates = chance.coordinates({format: 'ddm'})
let [ latitude, longitude ] = coordinates.split(',')
t.true(_.isString(coordinates))
t.is(coordinates.split(',').length, 2)
t.true(CHARS_TO_CONTAIN.every(char => latitude.includes(char)))
t.true(CHARS_TO_CONTAIN.every(char => longitude.includes(char)))
t.true(CHARS_NOT_TO_CONTAIN.every(char => !latitude.includes(char)))
t.true(CHARS_NOT_TO_CONTAIN.every(char => !longitude.includes(char)))
})
})
test('coordinates() will obey DMS format', t => {
_.times(1000, () => {
const CHARS_TO_CONTAIN = ['°', '’', '”']
let coordinates = chance.coordinates({format: 'dms'})
let [ latitude, longitude ] = coordinates.split(',')
t.true(_.isString(coordinates))
t.is(coordinates.split(',').length, 2)
t.true(CHARS_TO_CONTAIN.every(char => latitude.includes(char)))
t.true(CHARS_TO_CONTAIN.every(char => longitude.includes(char)))
})
})
// chance.counties()
test('counties() returns an array of counties', t => {
t.true(_.isArray(chance.counties()))
})
test('counties() returns a (long) county name', t => {
_.times(1000, () => t.true(chance.counties({ full: true }).length > 2))
})
test('counties() can return a random (long) county name', t => {
_.times(1000, () => {
t.true(chance.counties({ full: true, country: 'uk' }).length > 2)
})
})
// chance.countries()
test('countries() returns an array of countries', t => {
t.true(_.isArray(chance.countries()))
})
// chance.country()
test('country() returns a random (short) country name', t => {
_.times(1000, () => {
t.is(chance.country().length, 2)
})
})
test('country() returns a random (long) country name', t => {
_.times(1000, () => {
t.true(chance.country({ full: true }).length > 2)
})
})
// chance.county()
test('county() returns a random county name', t => {
_.times(1000, () => {
t.true(_.isString(chance.county()))
})
})
test('country() returns a random (long) country name', t => {
_.times(1000, () => {
t.true(chance.country({ full: true }).length > 2)
})
})
// chance.depth()
test('depth() looks right', t => {
t.is(typeof chance.depth(), 'number')
})
test('depth() is in the right range', t => {
_.times(1000, () => {
let depth = chance.depth()
t.true(depth > -10994)
t.true(depth < 0)
})
})
test('depth() will accept a min and obey it', t => {
_.times(1000, () => {
let min = chance.floating({ min: -10994, max: 0 })
let depth = chance.depth({ min: min })
t.true(depth > min)
t.true(depth < 0)
})
})
test('depth() will accept a max and obey it', t => {
_.times(1000, () => {
let max = chance.floating({ min: -10994, max: 0 })
let depth = chance.depth({ max: max })
t.true(depth > -10994)
t.true(depth < max)
})
})
// chance.geohash
test('geohash() looks right', t => {
let geohash = chance.geohash()
t.true(_.isString(geohash))
t.is(geohash.length, 7)
})
test('geohash() will accept a length and obey it', t => {
_.times(1000, () => {
let length = chance.d10()
let geohash = chance.geohash({ length: length })
t.is(geohash.length, length)
})
})
// chance.latitude()
test('latitude() looks right', t => {
t.is(typeof chance.latitude(), 'number')
})
test('latitude() is in the right range', t => {
_.times(1000, () => {
let latitude = chance.latitude()
t.true(latitude >= -90)
t.true(latitude <= 90)
})
})
test('latitude() will accept a min and obey it', t => {
_.times(1000, () => {
let min = chance.floating({ min: -90, max: 90 })
let latitude = chance.latitude({ min: min })
t.true(latitude >= min)
t.true(latitude <= 90)
})
})
test('latitude() will accept a max and obey it', t => {
_.times(1000, () => {
let max = chance.floating({ min: -90, max: 90 })
let latitude = chance.latitude({ max: max })
t.true(latitude >= -90)
t.true(latitude <= max)
})
})
test('latitude() returns latitude in DD format as default', t => {
_.times(1000, () => {
const CHARS_NOT_TO_CONTAIN = ['°', '’', '”']
let latitude = chance.latitude()
t.is(typeof latitude, 'number')
t.true(CHARS_NOT_TO_CONTAIN.every(char => !latitude.toString().includes(char)))
})
})
test('latitude() will obey DD format', t => {
_.times(1000, () => {
const CHARS_NOT_TO_CONTAIN = ['°', '’', '”']
let latitude = chance.latitude({format: 'dd'})
t.is(typeof latitude, 'number')
t.true(CHARS_NOT_TO_CONTAIN.every(char => !latitude.toString().includes(char)))
})
})
test('latitude() will obey DDM format', t => {
_.times(1000, () => {
const CHARS_TO_CONTAIN = ['°']
const CHARS_NOT_TO_CONTAIN = ['’', '”']
let latitude = chance.latitude({format: 'ddm'})
t.true(_.isString(latitude))
t.true(CHARS_TO_CONTAIN.every(char => latitude.includes(char)))
t.true(CHARS_NOT_TO_CONTAIN.every(char => !latitude.includes(char)))
})
})
test('latitude() will obey DMS format', t => {
_.times(1000, () => {
const CHARS_TO_CONTAIN = ['°', '’', '”']
let latitude = chance.latitude({format: 'dms'})
t.true(_.isString(latitude))
t.true(CHARS_TO_CONTAIN.every(char => latitude.includes(char)))
})
})
// chance.longitude()
test('longitude() looks right', t => {
t.is(typeof chance.longitude(), 'number')
})
test('longitude() is in the right range', t => {
_.times(1000, () => {
let longitude = chance.longitude()
t.true(longitude >= -180)
t.true(longitude <= 180)
})
})
test('longitude() will accept a min and obey it', t => {
_.times(1000, () => {
let min = chance.floating({ min: -180, max: 180 })
let longitude = chance.longitude({ min: min })
t.true(longitude >= min)
t.true(longitude <= 180)
})
})
test('longitude() will accept a max and obey it', t => {
_.times(1000, () => {
let max = chance.floating({ min: -180, max: 180 })
let longitude = chance.longitude({ max: max })
t.true(longitude >= -180)
t.true(longitude <= max)
})
})
test('longitude() returns longitude in DD format as default', t => {
_.times(1000, () => {
const CHARS_NOT_TO_CONTAIN = ['°', '’', '”']
let longitude = chance.longitude()
t.is(typeof longitude, 'number')
t.true(CHARS_NOT_TO_CONTAIN.every(char => !longitude.toString().includes(char)))
})
})
test('longitude() will obey DD format', t => {
_.times(1000, () => {
const CHARS_NOT_TO_CONTAIN = ['°', '’', '”']
let longitude = chance.longitude({format: 'dd'})
t.is(typeof longitude, 'number')
t.true(CHARS_NOT_TO_CONTAIN.every(char => !longitude.toString().includes(char)))
})
})
test('longitude() will obey DDM format', t => {
_.times(1000, () => {
const CHARS_TO_CONTAIN = ['°']
const CHARS_NOT_TO_CONTAIN = ['’', '”']
let longitude = chance.longitude({format: 'ddm'})
t.true(_.isString(longitude))
t.true(CHARS_TO_CONTAIN.every(char => longitude.includes(char)))
t.true(CHARS_NOT_TO_CONTAIN.every(char => !longitude.includes(char)))
})
})
test('longitude() will obey DMS format', t => {
_.times(1000, () => {
const CHARS_TO_CONTAIN = ['°', '’', '”']
let longitude = chance.longitude({format: 'dms'})
t.true(_.isString(longitude))
t.true(CHARS_TO_CONTAIN.every(char => longitude.includes(char)))
})
})
// chance.phone()
test('phone() returns a string', t => {
t.true(_.isString(chance.phone()))
})
test('phone() looks like an actual phone number', t => {
t.true(/^\(([2-9][0-8][0-9])\)?[\-. ]?([2-9][0-9]{2,2})[\-. ]?([0-9]{4,4})$/.test(chance.phone()))
})
test('phone() obeys formatted option', t => {
_.times(1000, () => {
let phone = chance.phone({ formatted: false })
t.true(_.isString(phone))
t.true(/^[2-9][0-8]\d[2-9]\d{6,6}$/.test(phone))
})
})
test('phone() obeys formatted option and parens option', t => {
_.times(1000, () => {
let phone = chance.phone({ formatted: false, parens: true })
t.true(_.isString(phone))
t.true(/^[2-9][0-8]\d[2-9]\d{6,6}$/.test(phone))
})
})
test('phone() with uk option works', t => {
t.true(_.isString(chance.phone({ country: 'uk' })))
})
test('phone() with uk option works and mobile option', t => {
t.true(_.isString(chance.phone({ country: 'uk', mobile: true })))
})
test('phone() with uk country looks right', t => {
t.true(phoneNumber.isValid(chance.phone({ country: 'uk' })))
})
test('phone() with uk country unformatted looks right', t => {
t.true(phoneNumber.isValid(phoneNumber.format(chance.phone({
country: 'uk',
formatted: false
}))))
})
test('phone() with uk country and mobile option looks right', t => {
_.times(1000, () => {
t.true(phoneNumber.isValid(chance.phone({
country: 'uk',
mobile: true
})))
})
})
test('phone() with uk country and mobile option unformatted looks right', t => {
_.times(1000, () => {
t.true(phoneNumber.isValid(phoneNumber.format(chance.phone({
country: 'uk',
mobile: true,
formatted: false
}))))
})
})
test('phone() with fr country works', t => {
t.true(_.isString(chance.phone({ country: 'fr' })))
})
test('phone() with fr country works with mobile option', t => {
t.true(_.isString(chance.phone({ country: 'fr', mobile: true })))
})
test('phone() with fr country looks right', t => {
_.times(1000, () => {
t.true(/0[123459] .. .. .. ../.test(chance.phone({ country: 'fr' })))
})
})
test('phone() with fr country looks right unformatted', t => {
_.times(1000, () => {
t.true(/0........./.test(chance.phone({
country: 'fr',
formatted: false
})))
})
})
test('phone() with fr country on mobile looks right', t => {
_.times(1000, () => {
t.true(/0[67] .. .. .. ../.test(chance.phone({
country: 'fr',
mobile: true
})))
})
})
test('phone() with fr country on mobile, unformatted looks right', t => {
_.times(1000, () => {
t.true(/0[67]......../.test(chance.phone({
country: 'fr',
mobile: true,
formatted: false
})))
})
})
test('phone() with br country option works', t => {
t.true(_.isString(chance.phone({ country: 'br' })))
})
test('phone() with br country and mobile option works', t => {
t.true(_.isString(chance.phone({ country: 'br', mobile: true })))
})
test('phone() with br country and formatted false option return a correct format', t => {
t.true(/([0-9]{2})([2-5]{1})([0-9]{3})([0-9]{4})/.test(chance.phone({
country: 'br',
mobile: false,
formatted: false
})))
})
test('phone() with br country, formatted false and mobile option return a correct format', t => {
t.true(/([0-9]{2})\9([0-9]{4})([0-9]{4})/.test(chance.phone({
country: 'br',
mobile: true,
formatted: false
})))
})
test('phone() with br country and formatted option apply the correct mask', t => {
t.true(/\(([0-9]{2})\) ([2-5]{1})([0-9]{3})\-([0-9]{4})/.test(chance.phone({
country: 'br',
mobile: false,
formatted: true
})))
})
test('phone() with br country, formatted and mobile option apply the correct mask', t => {
t.true(/\(([0-9]{2})\) 9([0-9]{4})\-([0-9]{4})/.test(chance.phone({
country: 'br',
mobile: true,
formatted: true
})))
})
// chance.postal()
test('postal() returns a valid basic postal code', t => {
_.times(1000, () => {
let postal = chance.postal()
t.is(postal.length, 7)
postal.split('').map((char) => {
t.is(char.toUpperCase(), char)
})
})
})
test('postcode() returns a valid basic postcode', t => {
_.times(10, () => {
let postcode = chance.postcode();
t.regex(postcode, /^[A-Z]{1,2}\d[A-Z\d]? \d[A-Z]{2}$/);
})
})
// chance.province()
test('province() returns a random (short) province name', t => {
_.times(1000, () => t.true(chance.province().length < 3))
})
test('province() can return a long random province name', t => {
_.times(1000, () => t.true(chance.province({ full: true }).length > 2))
})
test('province() can return a random long "it" province', t => {
_.times(1000, () => {
t.true(chance.province({country: 'it', full: true }).length > 2)
})
})
// chance.provinces()
test('provinces() returns an array of provinces', t => {
t.true(_.isArray(chance.provinces()))
})
test('provinces() supports internationalization', t => {
t.not(chance.provinces(), chance.provinces({ country: 'it' }))
})
// chance.state()
test('state() returns a random (short) state name', t => {
_.times(1000, () => t.true(chance.state().length < 3))
})
test('state() can take a country and return a state', t => {
_.times(1000, () => t.true(chance.state({ country: 'it' }).length === 3))
})
test('state() can return full state name', t => {
_.times(1000, () => {
t.true(chance.state({
full: true
}).length > 2)
})
})
test('state() with country returns a long state name', t => {
_.times(1000, () => {
t.true(chance.state({
country: 'it',
full: true
}).length > 2)
})
_.times(1000, () => {
t.true(chance.state({
country: 'uk',
full: true
}).length > 2)
})
})
// chance.states()
test('states() returns an array of states', t => {
t.true(_.isArray(chance.states()))
})
test('states() returns all 50 states and DC', t => {
t.is(chance.states().length, 51)
})
test('states() with territories returns 50 US states, DC, and 7 US territories', t => {
t.is(chance.states({
territories: true
}).length, 58)
})
test('states() without us states and dc returns 7 US territories', t => {
t.is(chance.states({
territories: true,
us_states_and_dc: false
}).length, 7)
})
test('states() with armed forces returns 50 states, DC, and 3 armed forces military states', t => {
t.is(chance.states({
armed_forces: true
}).length, 54)
})
test('states() with armed forces without states returns 3 armed forces states', t => {
t.is(chance.states({
armed_forces: true,
us_states_and_dc: false
}).length, 3)
})
test('states() with all options returns 61 items', t => {
t.is(chance.states({
territories: true,
armed_forces: true
}).length, 61)
})
test('states() without states returns 7 territories and 3 armed forces states', t => {
t.is(chance.states({
territories: true,
armed_forces: true,
us_states_and_dc: false
}).length, 10)
})
test('states() with country of "it" returns 20 regions', t => {
t.is(chance.states({
country: 'it'
}).length, 20)
})
test('states() with country of "uk" returns 129 UK counties', t => {
t.is(chance.states({
country: 'uk'
}).length, 129)
})
test('states() with country of "mx" returns 32 MX states', t => {
t.is(chance.states({
country: 'mx'
}).length, 32)
})
// chance.street()
test('street() works', t => {
_.times(100, () => t.is(typeof chance.street(), 'string'))
})
test('street() works with it country', t => {
_.times(100, () => t.is(typeof chance.street({ country: 'it' }), 'string'))
})
// chance.street_suffix()
test('street_suffix() returns a single suffix', t => {
_.times(1000, () => {
let suffix = chance.street_suffix()
t.is(typeof suffix, 'object')
t.is(typeof suffix.name, 'string')
t.is(typeof suffix.abbreviation, 'string')
})
})
// chance.street_suffixes()
test('street_suffixes() returns the suffix array', t => {
let suffixes = chance.street_suffixes()
t.true(_.isArray(suffixes))
suffixes.map((suffix) => {
t.truthy(suffix.name)
t.truthy(suffix.abbreviation)
})
})
test('street_suffixes() are short', t => {
let suffixes = chance.street_suffixes()
suffixes.map((suffix) => {
t.true(suffix.abbreviation.length < 5)
})
})
test('street_suffixes() are longish', t => {
let suffixes = chance.street_suffixes()
suffixes.map((suffix) => {
t.true(suffix.name.length > 2)
})
})
// chance.zip()
test('zip() returns a valid basic zip code', t => {
_.times(1000, () => {
let zip = chance.zip()
t.is(zip.length, 5)
t.true(/(^\d{5}$)|(^\d{5}-\d{4}$)/.test(zip))
})
})
test('zip() returns a valid zip+4 code', t => {
_.times(1000, () => {
let zip = chance.zip({ plusfour: true })
t.is(zip.length, 10)
t.true(/(^\d{5}$)|(^\d{5}-\d{4}$)/.test(zip))
})
})