use ncc & test on dist

pull/38/head
Amio 2019-01-29 20:53:41 +08:00
rodzic 22aa7c1691
commit 5fc35ca0cc
13 zmienionych plików z 93 dodań i 2842 usunięć

4
.gitignore vendored
Wyświetl plik

@ -1,3 +1,3 @@
node_modules
.nyc_output
badgen.min.js
node_modules
dist

Wyświetl plik

@ -1,4 +1,5 @@
.*
src
test
bench
preview

2817
package-lock.json wygenerowano

Plik diff jest za duży Load Diff

Wyświetl plik

@ -5,23 +5,22 @@
"repository": "amio/badgen",
"author": "Amio <amio.cn@gmail.com>",
"license": "ISC",
"main": "lib/index.js",
"main": "dist/index.js",
"scripts": {
"lint": "standard",
"bench": "node bench/index.js",
"preview": "node preview/serve.js",
"snaptests": "TAP_SNAPSHOT=1 npm test",
"pretest": "npm run lint",
"pretest": "npm run lint && npm run build",
"test": "tap test/*.spec.js --reporter spec --coverage",
"build": "lyo -o badgen.min.js",
"build": "ncc -s -m build src/index.js ",
"prepublishOnly": "npm run build"
},
"devDependencies": {
"@zeit/ncc": "^0.13.0",
"benchmark": "^2.1.4",
"serve-marked": "0.4.0",
"standard": "^12.0.0",
"tap": "^12.0.1",
"lyo": "latest"
},
"dependencies": {}
"tap": "^12.0.1"
}
}

Wyświetl plik

@ -5,7 +5,6 @@ const sanitize = str => str.replace(/\u0026/g, '&amp;').replace(/\u003C/g, '&lt;
const bare = require('./bare.js')
module.exports = ({ subject, status, color, style, icon, iconWidth = 13 }) => {
typeAssert(typeof subject === 'string', '<subject> must be string')
typeAssert(typeof status === 'string', '<status> must be string')
if (!subject && !icon) {

Wyświetl plik

@ -162,3 +162,51 @@ exports[`test/index.spec.js TAP generate badge with { subject, status, icon, sty
<image x="40" y="35" width="130" height="132" xlink:href=""/>
</svg>
`
exports[`test/index.spec.js TAP generate bare badge with { status } > snapshot 1`] = `
<svg width="47" height="20" viewBox="0 0 470 200" xmlns="http://www.w3.org/2000/svg">
<linearGradient id="a" x2="0" y2="100%">
<stop offset="0" stop-opacity=".1" stop-color="#EEE"/>
<stop offset="1" stop-opacity=".1"/>
</linearGradient>
<mask id="m"><rect width="470" height="200" rx="30" fill="#FFF"/></mask>
<g mask="url(#m)">
<rect width="470" height="200" fill="#08C" x="0"/>
<rect width="470" height="200" fill="url(#a)"/>
</g>
<g fill="#fff" text-anchor="start" font-family="Verdana,DejaVu Sans,sans-serif" font-size="110">
<text x="65" y="148" textLength="355" fill="#000" opacity="0.25">v1.0.0</text>
<text x="55" y="138" textLength="355">v1.0.0</text>
</g>
</svg>
`
exports[`test/index.spec.js TAP generate bare badge with { status, color } > snapshot 1`] = `
<svg width="47" height="20" viewBox="0 0 470 200" xmlns="http://www.w3.org/2000/svg">
<linearGradient id="a" x2="0" y2="100%">
<stop offset="0" stop-opacity=".1" stop-color="#EEE"/>
<stop offset="1" stop-opacity=".1"/>
</linearGradient>
<mask id="m"><rect width="470" height="200" rx="30" fill="#FFF"/></mask>
<g mask="url(#m)">
<rect width="470" height="200" fill="#ADF" x="0"/>
<rect width="470" height="200" fill="url(#a)"/>
</g>
<g fill="#fff" text-anchor="start" font-family="Verdana,DejaVu Sans,sans-serif" font-size="110">
<text x="65" y="148" textLength="355" fill="#000" opacity="0.25">v1.0.0</text>
<text x="55" y="138" textLength="355">v1.0.0</text>
</g>
</svg>
`
exports[`test/index.spec.js TAP generate bare badge with { status, style } > snapshot 1`] = `
<svg width="47" height="20" viewBox="0 0 470 200" xmlns="http://www.w3.org/2000/svg">
<g>
<rect fill="#08C" x="0" width="470" height="200"/>
</g>
<g fill="#fff" text-anchor="start" font-family="Verdana,DejaVu Sans,sans-serif" font-size="110">
<text x="65" y="148" textLength="355" fill="#000" opacity="0.1">v1.0.0</text>
<text x="55" y="138" textLength="355">v1.0.0</text>
</g>
</svg>
`

Wyświetl plik

@ -1,23 +0,0 @@
const tap = require('tap')
const bare = require('../lib/bare.js')
tap.test('generate bare badge with { status }', t => {
const svg = bare({ status: 'v1.0.0' })
t.ok(typeof svg === 'string', 'successfully generated')
t.matchSnapshot(svg, 'snapshot')
t.end()
})
tap.test('generate bare badge with { status, color }', t => {
const svg = bare({ status: 'v1.0.0', color: 'ADF' })
t.ok(typeof svg === 'string', 'successfully generated')
t.matchSnapshot(svg, 'snapshot')
t.end()
})
tap.test('generate bare badge with { status, style }', t => {
const svg = bare({ status: 'v1.0.0', style: 'flat' })
t.ok(typeof svg === 'string', 'successfully generated')
t.matchSnapshot(svg, 'snapshot')
t.end()
})

Wyświetl plik

@ -1,5 +1,5 @@
const tap = require('tap')
const calcWidth = require('../lib/calc-text-width.js').Verdana110
const calcWidth = require('../src/calc-text-width.js').Verdana110
tap.test('basic functions', t => {
t.ok(typeof calcWidth === 'function', 'export calcWidth function')

Wyświetl plik

@ -54,8 +54,28 @@ tap.test('generate badge with { subject, status, icon, style }', t => {
t.end()
})
tap.test('type checking', t => {
t.throws(() => badgen({ status: '' }), TypeError, 'throw if subject is non-string')
t.throws(() => badgen({ subject: '' }), TypeError, 'throw if status is non-string')
tap.test('generate bare badge with { status }', t => {
const svg = badgen({ status: 'v1.0.0' })
t.ok(typeof svg === 'string', 'successfully generated')
t.matchSnapshot(svg, 'snapshot')
t.end()
})
tap.test('generate bare badge with { status, color }', t => {
const svg = badgen({ status: 'v1.0.0', color: 'ADF' })
t.ok(typeof svg === 'string', 'successfully generated')
t.matchSnapshot(svg, 'snapshot')
t.end()
})
tap.test('generate bare badge with { status, style }', t => {
const svg = badgen({ status: 'v1.0.0', style: 'flat' })
t.ok(typeof svg === 'string', 'successfully generated')
t.matchSnapshot(svg, 'snapshot')
t.end()
})
tap.test('type checking', t => {
t.throws(() => badgen({}), TypeError, 'throw if status is non-string')
t.end()
})