chroma-js
Version:
JavaScript library for color conversions
192 lines (154 loc) • 8.56 kB
text/coffeescript
require 'es6-shim'
vows = require 'vows'
assert = require 'assert'
chroma = require '../chroma'
round = (digits) ->
d = Math.pow 10,digits
return (v) ->
Math.round(v*d) / d
vows
.describe('Some tests for chroma.color()')
.addBatch
'named colors':
topic: chroma 'red'
'hex': (topic) -> assert.equal topic.hex(), '#ff0000'
'rgb': (topic) -> assert.deepEqual topic.rgb(), [255,0,0]
'hex colors':
topic: chroma '#f00'
'name': (topic) -> assert.equal topic.name(), 'red'
'hex': (topic) -> assert.equal topic.hex(), '#ff0000'
'hex rgba': (topic) -> assert.equal topic.hex('rgba'), '#ff0000ff'
'hex argb': (topic) -> assert.equal topic.hex('argb'), '#ffff0000'
'rgb': (topic) -> assert.deepEqual topic.rgb(), [255,0,0]
'hex color, no #':
topic: chroma 'F00'
'name': (topic) -> assert.equal topic.name(), 'red'
'hex': (topic) -> assert.equal topic.hex(), '#ff0000'
'rgb': (topic) -> assert.deepEqual topic.rgb(), [255,0,0]
'gl color':
topic: chroma.gl 1,0,0
'name': (topic) -> assert.equal topic.name(), 'red'
'hex': (topic) -> assert.equal topic.hex(), '#ff0000'
'rgb': (topic) -> assert.deepEqual topic.rgb(), [255,0,0]
'gl color non-1':
topic: chroma.gl 1,0.5,0.2
'hex': (topic) -> assert.equal topic.hex(), '#ff7f33'
'rgb': (topic) -> assert.deepEqual topic.rgb(), [255,127.5,51]
'gl color w/ alpha':
topic: chroma.gl 0,0,1,0.5
'rgba': (topic) -> assert.deepEqual topic.rgba(), [0,0,255,0.5]
'modify colors':
topic: chroma 'F00'
'darken': (topic) -> assert.equal topic.darken(10).hex(), '#dd0000'
'darker': (topic) -> assert.equal topic.darker(10).hex(), '#dd0000'
'brighten': (topic) -> assert.equal topic.brighten(10).hex(), '#ff3e20'
'brighter': (topic) -> assert.equal topic.brighter(10).hex(), '#ff3e20'
'saturate': (topic) -> assert.equal topic.saturate().hex(), '#ff0000'
'desaturate': (topic) -> assert.equal topic.desaturate().hex(), '#ec3d23'
'parsing css color rgb':
topic: chroma 'rgb(255,0,0)'
'hex': (topic) -> assert.equal topic.hex(), '#ff0000'
'parsing rgba css color':
topic: chroma 'rgba(128,0,128,0.5)'
'hex': (topic) -> assert.equal topic.hex(), '#800080'
'alpha': (topic) -> assert.equal topic.alpha(), 0.5
'css': (topic) -> assert.equal topic.css(), 'rgba(128,0,128,0.5)'
'parsing hsla css color':
topic: chroma 'hsla(240,100%,50%,0.5)'
'hex': (topic) -> assert.equal topic.hex(), '#0000ff'
'alpha': (topic) -> assert.equal topic.alpha(), 0.5
'css': (topic) -> assert.equal topic.css(), 'rgba(0,0,255,0.5)'
'hsla color':
topic: chroma 'lightsalmon'
'css (default)': (topic) -> assert.equal topic.css(), 'rgb(255,160,122)'
'css (rgb)': (topic) -> assert.equal topic.css('rgb'), 'rgb(255,160,122)'
'css (hsl)': (topic) -> assert.equal chroma(topic.css('hsl')).name(), 'lightsalmon'
'css (rgb-css)': (topic) -> assert.equal chroma(topic.css('rgb')).name(), 'lightsalmon'
'rgb color':
topic: chroma 255,0,0
'hex': (topic) -> assert.equal topic.hex(), '#ff0000'
'hsv black':
topic: chroma('black').hsv()
'hue is NaN': (topic) -> assert isNaN topic[0]
'but hue is defined': (topic) -> assert topic[0]?
'interpolate in hsv':
topic: chroma.interpolate 'white', 'black', 0.5, 'hsv'
'hex': (topic) -> assert.equal topic.hex(), '#808080'
'hsl black':
topic: chroma('black').hsl()
'hue is NaN': (topic) -> assert isNaN topic[0]
'but hue is defined': (topic) -> assert topic[0]?
'sat is 0': (topic) -> assert.equal topic[1], 0
'lightness is 0': (topic) -> assert.equal topic[2], 0
'interpolate in hsl':
topic: chroma.interpolate 'lightyellow', 'navy', 0.5, 'hsl'
'hex': (topic) -> assert.equal topic.hex(), '#31ff98'
'premultiply':
topic: chroma 'rgba(32, 48, 96, 0.5)'
'premultiply rgba': (topic) -> assert.deepEqual topic.premultiply().rgba(), [16, 24, 48, 0.5]
'premultiply hex': (topic) -> assert.equal topic.premultiply().hex(), '#101830'
'premultiply num': (topic) -> assert.equal topic.premultiply().num(), 0x101830
'toString':
topic: chroma '#adff2f'
'explicit': (topic) -> assert.equal topic.toString(), 'greenyellow'
'implicit': (topic) -> assert.equal ''+topic, 'greenyellow'
'implicit2': (topic) -> assert.equal String(topic), 'greenyellow'
'constructing with array, but no mode':
topic: chroma [255, 0, 0]
'falls back to rgb': (topic) -> assert.equal topic.hex(), chroma([255, 0, 0],'rgb').hex()
'css rgb colors':
topic: chroma.scale("YlGnBu")(0.3).css()
'have rounded rgb() values': (topic) -> assert.equal topic, 'rgb(170,222,183)'
'css rgba colors':
topic: chroma.scale("YlGnBu")(0.3).alpha(0.675).css()
'dont round alpha value': (topic) -> assert.equal topic, 'rgba(170,222,183,0.675)'
'random colors':
topic: chroma.random()
'valid hex code': (topic) -> assert /^#[0-9a-f]{6}$/i.test(topic.hex())
'constructing numeric color':
topic: chroma.num 0xff0000
'color is red': (topic) -> assert.equal topic.name(), 'red'
'alpha is 100%': (topic) -> assert.equal topic.alpha(), 1
'number output':
topic: chroma.hsl 0,1,0.5,0.5
'numoutput': -> (topic) -> assert.equal topic.num(), 0xff0000
'num color':
topic: [chroma(0xff0000), chroma(0x000000), chroma(0xffffff), chroma(0x31ff98), chroma('red')]
'hex': (topic) -> assert.equal topic[0].hex(), '#ff0000'
'num': (topic) -> assert.equal topic[0].num(), 0xff0000
'hex-black': (topic) -> assert.equal topic[1].hex(), '#000000'
'num-black': (topic) -> assert.equal topic[1].num(), 0x000000
'hex-white': (topic) -> assert.equal topic[2].hex(), '#ffffff'
'num-white': (topic) -> assert.equal topic[2].num(), 0xffffff
'hex-rand': (topic) -> assert.equal topic[3].hex(), '#31ff98'
'num-rand': (topic) -> assert.equal topic[3].num(), 0x31ff98
'rum-red': (topic) -> assert.equal topic[4].num(), 0xff0000
'interpolate in num':
topic: chroma.interpolate chroma.num(0xffffe0), chroma.num(0x102180), 0.5, 'num'
'hex': (topic) -> assert.equal topic.hex(), '#8790b0'
'num': (topic) -> assert.equal topic.num(), 8884400
'normalize hue':
topic: chroma.rgb(0,255,255).lch()
'hue > 0': (topic) -> assert topic[2] >= 0
'hue < 360': (topic) -> assert topic[2] <= 360
'lab conversion red':
topic: chroma('red').lab().map(round(3))
'is right': (topic) -> assert.deepEqual topic, [53.241, 80.092, 67.203]
'lab conversion blue':
topic: chroma('blue').lab().map(round(3))
'is right': (topic) -> assert.deepEqual topic, [32.297, 79.188, -107.86]
'lab conversion green':
topic: chroma('green').lab().map(round(3))
'is right': (topic) -> assert.deepEqual topic, [46.227, -51.698, 49.897]
'lab conversion yellow':
topic: chroma('yellow').lab().map(round(3))
'is right': (topic) -> assert.deepEqual topic, [97.139, -21.554, 94.478]
'lab conversion magenta':
topic: chroma('magenta').lab().map(round(3))
'is right': (topic) -> assert.deepEqual topic, [60.324, 98.234, -60.825]
'hueless css hsl colors':
topic: [chroma('black'), chroma('gray'), chroma('white')]
'black': (topic) -> assert.equal topic[0].css('hsl'), 'hsl(0,0%,0%)'
'gray': (topic) -> assert.equal topic[1].css('hsl'), 'hsl(0,0%,50.2%)'
'white': (topic) -> assert.equal topic[2].css('hsl'), 'hsl(0,0%,100%)'
.export(module)