Files
vue-cli/packages/@vue/cli-service-global/__tests__/globalServiceBuildLib.spec.js
2018-08-14 11:10:02 -04:00

64 lines
1.8 KiB
JavaScript

jest.setTimeout(20000)
const fs = require('fs-extra')
const path = require('path')
const portfinder = require('portfinder')
const { createServer } = require('http-server')
const execa = require('execa')
const launchPuppeteer = require('@vue/cli-test-utils/launchPuppeteer')
const cwd = path.resolve(__dirname, 'temp')
const binPath = require.resolve('@vue/cli/bin/vue')
const write = (file, content) => fs.writeFile(path.join(cwd, file), content)
const entryVue = fs.readFileSync(path.resolve(__dirname, 'entry.vue'), 'utf-8')
beforeAll(async () => {
await fs.ensureDir(cwd)
await write('testLib.vue', entryVue)
})
let server, browser, page
test('global build --target lib', async () => {
const { stdout } = await execa(binPath, ['build', 'testLib.vue', '--target', 'lib'], { cwd })
expect(stdout).toMatch('Build complete.')
const distDir = path.join(cwd, 'dist')
const hasFile = file => fs.existsSync(path.join(distDir, file))
expect(hasFile('demo.html')).toBe(true)
expect(hasFile('testLib.common.js')).toBe(true)
expect(hasFile('testLib.umd.js')).toBe(true)
expect(hasFile('testLib.umd.min.js')).toBe(true)
expect(hasFile('testLib.css')).toBe(true)
const port = await portfinder.getPortPromise()
server = createServer({ root: distDir })
await new Promise((resolve, reject) => {
server.listen(port, err => {
if (err) return reject(err)
resolve()
})
})
const launched = await launchPuppeteer(`http://localhost:${port}/demo.html`)
browser = launched.browser
page = launched.page
const h1Text = await page.evaluate(() => {
return document.querySelector('h1').textContent
})
expect(h1Text).toMatch('hi')
})
afterAll(async () => {
if (browser) {
await browser.close()
}
if (server) {
server.close()
}
})