import { existsSync } from 'fs' import http from 'http' import { resolve } from 'path' import { remove } from 'fs-extra' import serveStatic from 'serve-static' import finalhandler from 'finalhandler' import { loadFixture, getPort, Nuxt, Generator, Builder, rp } from '../utils' let port const url = route => 'http://localhost:' + port + route const rootDir = resolve(__dirname, '..', 'fixtures/basic') const distDir = resolve(rootDir, '.nuxt-generate') let server = null let generator = null describe('basic generate', () => { beforeAll(async () => { const config = loadFixture('basic', {generate: {dir: '.nuxt-generate'}}) const nuxt = new Nuxt(config) const builder = new Builder(nuxt) builder.build = jest.fn() generator = new Generator(nuxt, builder) await generator.generate() const serve = serveStatic(distDir) server = http.createServer((req, res) => { serve(req, res, finalhandler(req, res)) }) port = await getPort() server.listen(port) }) test('Check builder', async () => { expect(generator.builder.isStatic).toBe(true) expect(generator.builder.build).toHaveBeenCalledTimes(1) }) test('Check ready hook called', async () => { expect(generator.nuxt.__hook_called__).toBe(true) }) test('Format errors', async () => { const error = generator._formatErrors([ { type: 'handled', route: '/h1', error: 'page not found' }, { type: 'unhandled', route: '/h2', error: { stack: 'unhandled error stack' } } ]) expect(error).toMatch(' GEN ERR ') expect(error).toMatch(' /h1') expect(error).toMatch(' /h2') expect(error).toMatch('"page not found"') expect(error).toMatch('unhandled error stack') }) test('/stateless', async () => { const window = await generator.nuxt.renderAndGetWindow(url('/stateless')) const html = window.document.body.innerHTML expect(html.includes('

My component!

')).toBe(true) }) test('/css', async () => { const window = await generator.nuxt.renderAndGetWindow(url('/css')) const headHtml = window.document.head.innerHTML expect(headHtml.includes('.red{color:red')).toBe(true) const element = window.document.querySelector('.red') expect(element).not.toBe(null) expect(element.textContent).toBe('This is red') expect(element.className).toBe('red') // t.is(window.getComputedStyle(element), 'red') }) test('/stateful', async () => { const window = await generator.nuxt.renderAndGetWindow(url('/stateful')) const html = window.document.body.innerHTML expect(html.includes('

The answer is 42

')).toBe(true) }) test('/head', async () => { const window = await generator.nuxt.renderAndGetWindow(url('/head')) const html = window.document.body.innerHTML const metas = window.document.getElementsByTagName('meta') expect(window.document.title).toBe('My title - Nuxt.js') expect(metas[0].getAttribute('content')).toBe('my meta') expect(html.includes('

I can haz meta tags

')).toBe(true) }) test('/async-data', async () => { const window = await generator.nuxt.renderAndGetWindow(url('/async-data')) const html = window.document.body.innerHTML expect(html.includes('

Nuxt.js

')).toBe(true) }) test('/users/1/index.html', async () => { const html = await rp(url('/users/1/index.html')) expect(html.includes('

User: 1

')).toBe(true) expect( existsSync(resolve(distDir, 'users/1/index.html')) ).toBe(true) expect(existsSync(resolve(distDir, 'users/1.html'))).toBe(false) }) test('/users/2', async () => { const html = await rp(url('/users/2')) expect(html.includes('

User: 2

')).toBe(true) }) test('/users/3 (payload given)', async () => { const html = await rp(url('/users/3')) expect(html.includes('

User: 3000

')).toBe(true) }) test('/users/4 -> Not found', async () => { await expect(rp(url('/users/4'))).rejects.toMatchObject({ statusCode: 404, response: { body: expect.stringContaining('Cannot GET /users/4') } }) }) test('/validate should not be server-rendered', async () => { const html = await rp(url('/validate')) expect(html.includes('
')).toBe(true) expect(html.includes('serverRendered:!1')).toBe(true) }) test('/validate -> should display a 404', async () => { const window = await generator.nuxt.renderAndGetWindow(url('/validate')) const html = window.document.body.innerHTML expect(html.includes('This page could not be found')).toBe(true) }) test('/validate?valid=true', async () => { const window = await generator.nuxt.renderAndGetWindow(url('/validate?valid=true')) const html = window.document.body.innerHTML expect(html.includes('I am valid')).toBe(true) }) test('/redirect should not be server-rendered', async () => { const html = await rp(url('/redirect')) expect(html.includes('
')).toBe(true) expect(html.includes('serverRendered:!1')).toBe(true) }) test('/redirect -> check redirected source', async () => { const window = await generator.nuxt.renderAndGetWindow(url('/redirect')) const html = window.document.body.innerHTML expect(html.includes('

Index page

')).toBe(true) }) test('/users/1 not found', async () => { await remove(resolve(distDir, 'users')) await expect(rp(url('/users/1'))).rejects.toMatchObject({ statusCode: 404, response: { body: expect.stringContaining('Cannot GET /users/1') } }) }) test('nuxt re-generating with no subfolders', async () => { generator.nuxt.options.generate.subFolders = false await expect(generator.generate({ build: false })).resolves.toBeTruthy() }) test('/users/1.html', async () => { const html = await rp(url('/users/1.html')) expect(html.includes('

User: 1

')).toBe(true) expect(existsSync(resolve(distDir, 'users/1.html'))).toBe(true) expect( existsSync(resolve(distDir, 'users/1/index.html')) ).toBe(false) }) test('/-ignored', async () => { await expect(rp(url('/-ignored'))).rejects.toMatchObject({ statusCode: 404, response: { body: expect.stringContaining('Cannot GET /-ignored') } }) }) test('/ignored.test', async () => { await expect(rp(url('/ignored.test'))).rejects.toMatchObject({ statusCode: 404, response: { body: expect.stringContaining('Cannot GET /ignored.test') } }) }) // Close server and ask nuxt to stop listening to file changes afterAll(async () => { await server.close() }) })