import test from 'ava' import { resolve, normalize } from 'path' import rp from 'request-promise-native' import { Nuxt, Builder } from '../index.js' const port = 4006 const url = (route) => 'http://localhost:' + port + route let nuxt = null // Init nuxt.js and create server listening on localhost:4000 test.before('Init Nuxt.js', async t => { const rootDir = resolve(__dirname, 'fixtures/module') let config = require(resolve(rootDir, 'nuxt.config.js')) config.rootDir = rootDir config.dev = false nuxt = new Nuxt(config) await new Builder(nuxt).build() await nuxt.listen(port, 'localhost') }) test('Vendor', async t => { t.true(nuxt.options.build.vendor.indexOf('lodash') !== -1, 'lodash added to config') }) test('Plugin', async t => { t.true(normalize(nuxt.options.plugins[0].src) .includes(normalize('fixtures/module/.nuxt/basic.reverse.')), 'plugin added to config') const { html } = await nuxt.renderRoute('/') t.true(html.includes('

TXUN

'), 'plugin works') }) test('Middleware', async t => { let response = await rp(url('/api')) t.is(response, 'It works!', '/api response is correct') }) test('Tapable', async t => { t.is(nuxt.__module_hook, 1) t.is(nuxt.__renderer_hook, 2) t.is(nuxt.__builder_hook, 3) }) // Close server and ask nuxt to stop listening to file changes test.after('Closing server and nuxt.js', t => { nuxt.close() })