2ba352da39
* Initial move * Make emitting work * Update paths * Remove leftover files * Add correct externals configuration * Import correct path * Update path to work with ts-server test * Update lib directory * Compile next-server/lib
56 lines
1.8 KiB
JavaScript
56 lines
1.8 KiB
JavaScript
/* eslint-env jest */
|
|
import { loadGetInitialProps } from 'next/dist/next-server/lib/utils'
|
|
|
|
describe('loadGetInitialProps', () => {
|
|
it('should throw if getInitialProps is defined as an instance method', () => {
|
|
class TestComponent {
|
|
getInitialProps () {}
|
|
}
|
|
const rejectPromise = loadGetInitialProps(TestComponent, {})
|
|
const error = new Error(
|
|
'"TestComponent.getInitialProps()" is defined as an instance method - visit https://err.sh/zeit/next.js/get-initial-props-as-an-instance-method for more information.'
|
|
)
|
|
return expect(rejectPromise).rejects.toEqual(error)
|
|
})
|
|
|
|
it('should resolve to an empty object if getInitialProps is missing', async () => {
|
|
const result = await loadGetInitialProps(() => {}, {})
|
|
expect(result).toEqual({})
|
|
})
|
|
|
|
it('should resolve getInitialProps', async () => {
|
|
class TestComponent {
|
|
static async getInitialProps () {
|
|
return { foo: 1 }
|
|
}
|
|
}
|
|
const result = await loadGetInitialProps(TestComponent, {})
|
|
expect(result).toEqual({ foo: 1 })
|
|
})
|
|
|
|
it('should be able to return an invalid value if the request was already sent', async () => {
|
|
class TestComponent {
|
|
static async getInitialProps () {
|
|
return 'invalidValue'
|
|
}
|
|
}
|
|
const ctx = {
|
|
res: {
|
|
finished: true
|
|
}
|
|
}
|
|
const result = await loadGetInitialProps(TestComponent, ctx)
|
|
expect(result).toBe('invalidValue')
|
|
})
|
|
|
|
it("should throw if getInitialProps won't return an object ", () => {
|
|
class TestComponent {
|
|
static async getInitialProps () {}
|
|
}
|
|
const rejectPromise = loadGetInitialProps(TestComponent, {})
|
|
const error = new Error(
|
|
'"TestComponent.getInitialProps()" should resolve to an object. But found "undefined" instead.'
|
|
)
|
|
return expect(rejectPromise).rejects.toEqual(error)
|
|
})
|
|
})
|