Skip to content

Commit

Permalink
fix: fix fetching adapters manifest from latest gatsby version (#38475)
Browse files Browse the repository at this point in the history
* fix: fix fetching adapters manifest from latest gatsby version

* add test for .js module fetching and loading

* drop .only
  • Loading branch information
pieh authored Aug 25, 2023
1 parent d1bcd93 commit d1e6aea
Show file tree
Hide file tree
Showing 2 changed files with 117 additions and 42 deletions.
125 changes: 97 additions & 28 deletions packages/gatsby/src/utils/__tests__/get-latest-gatsby-files.ts
Original file line number Diff line number Diff line change
@@ -1,9 +1,22 @@
const mockFiles = new Map<string, string>()

/* eslint-disable @typescript-eslint/no-var-requires */
jest.mock(`fs-extra`, () => {
return {
readJSON: jest.fn(),
writeFile: jest.fn(),
pathExists: jest.fn(),
readJSON: jest.fn().mockImplementation(async filePath => {
const content = mockFiles.get(filePath)

if (content) {
return JSON.parse(content)
}
throw new Error(`File not found`)
}),
writeFile: jest.fn().mockImplementation(async (filePath, content) => {
mockFiles.set(filePath, content)
}),
pathExists: jest
.fn()
.mockImplementation(async filePath => mockFiles.has(filePath)),
}
})
jest.mock(`axios`, () => {
Expand All @@ -13,13 +26,49 @@ jest.mock(`axios`, () => {
})

const path = require(`path`)

const latestAdaptersModulePath = path.join(
__dirname,
`..`,
`..`,
`..`,
`latest-adapters.js`
)

const latestAdaptersMarker = `<mocked-adapters-js>`

const mockAdaptersManifest: Array<IAdapterManifestEntry> = [
{
name: `Mock`,
module: `mock-adapter`,
test: () => !!process.env.MOCK_ADAPTER,
versions: [],
},
]

jest.doMock(
latestAdaptersModulePath,
(): Array<IAdapterManifestEntry> => {
if (mockFiles.get(latestAdaptersModulePath) === latestAdaptersMarker) {
return mockAdaptersManifest
}
throw new Error(`Module not found`)
},
{ virtual: true }
)

const fs = require(`fs-extra`)
const axios = require(`axios`)
import { getLatestAPIs, IAPIResponse } from "../get-latest-gatsby-files"
import { IAdapterManifestEntry } from "../adapter/types"
import {
getLatestAPIs,
getLatestAdapters,
IAPIResponse,
} from "../get-latest-gatsby-files"

beforeEach(() => {
;[fs, axios].forEach(mock =>
Object.keys(mock).forEach(key => mock[key].mockReset())
Object.keys(mock).forEach(key => mock[key].mockClear())
)
})

Expand All @@ -32,29 +81,53 @@ const getMockAPIFile = (): IAPIResponse => {
}

describe(`default behavior: has network connectivity`, () => {
beforeEach(() => {
fs.pathExists.mockResolvedValueOnce(false)
axios.get.mockResolvedValueOnce({ data: getMockAPIFile() })
})
describe(`getLatestAPIs`, () => {
beforeEach(() => {
axios.get.mockResolvedValueOnce({ data: getMockAPIFile() })
})

it(`makes a request to unpkg to request file`, async () => {
const data = await getLatestAPIs()
it(`makes a request to unpkg to request file`, async () => {
const data = await getLatestAPIs()

expect(axios.get).toHaveBeenCalledWith(
expect.stringContaining(`unpkg.com`),
expect.any(Object)
)
expect(data).toEqual(getMockAPIFile())
expect(axios.get).toHaveBeenCalledWith(
expect.stringContaining(`unpkg.com`),
expect.any(Object)
)
expect(data).toEqual(getMockAPIFile())
})

it(`writes apis.json file`, async () => {
const data = await getLatestAPIs()

expect(fs.writeFile).toHaveBeenCalledWith(
expect.stringContaining(`latest-apis.json`),
JSON.stringify(data, null, 2),
expect.any(String)
)
})
})

it(`writes apis.json file`, async () => {
const data = await getLatestAPIs()
describe(`getLatestAdapters`, () => {
beforeEach(() => {
axios.get.mockResolvedValueOnce({ data: latestAdaptersMarker })
})

expect(fs.writeFile).toHaveBeenCalledWith(
expect.stringContaining(`latest-apis.json`),
JSON.stringify(data, null, 2),
expect.any(String)
)
it(`loads .js modules`, async () => {
const data = await getLatestAdapters()

expect(axios.get).toHaveBeenCalledWith(
expect.stringContaining(`unpkg.com`),
expect.any(Object)
)

expect(fs.writeFile).toHaveBeenCalledWith(
expect.stringContaining(`latest-adapters.js`),
latestAdaptersMarker,
expect.any(String)
)

expect(data).toEqual(mockAdaptersManifest)
})
})
})

Expand All @@ -65,8 +138,6 @@ describe(`downloading APIs failure`, () => {

it(`falls back to downloaded cached file, if it exists`, async () => {
const apis = getMockAPIFile()
fs.pathExists.mockResolvedValueOnce(true)
fs.readJSON.mockResolvedValueOnce(apis)

const data = await getLatestAPIs()

Expand All @@ -78,9 +149,7 @@ describe(`downloading APIs failure`, () => {
})

it(`falls back to local apis.json if latest-apis.json not cached`, async () => {
const apis = getMockAPIFile()
fs.pathExists.mockResolvedValueOnce(false)
fs.readJSON.mockResolvedValueOnce(apis)
mockFiles.clear()

await getLatestAPIs()

Expand Down
34 changes: 20 additions & 14 deletions packages/gatsby/src/utils/get-latest-gatsby-files.ts
Original file line number Diff line number Diff line change
Expand Up @@ -32,30 +32,36 @@ const _getFile = async <T>({
outputFileName: string
defaultReturn: T
}): Promise<T> => {
let fileToUse = path.join(ROOT, fileName)
try {
const { data } = await axios.get(`${UNPKG_ROOT}${fileName}`, {
timeout: 5000,
})

await fs.writeFile(outputFileName, JSON.stringify(data, null, 2), `utf8`)
await fs.writeFile(
outputFileName,
typeof data === `string` ? data : JSON.stringify(data, null, 2),
`utf8`
)

return data
fileToUse = outputFileName
} catch (e) {
// if file was previously cached, use it
if (await fs.pathExists(outputFileName)) {
return fs.readJSON(outputFileName)
fileToUse = outputFileName
}
}

if (fileName.endsWith(`.json`)) {
return fs.readJSON(path.join(ROOT, fileName)).catch(() => defaultReturn)
} else {
try {
const importedFile = await import(path.join(ROOT, fileName))
const adapters = preferDefault(importedFile)
return adapters
} catch (e) {
// no-op
return defaultReturn
}
if (fileToUse.endsWith(`.json`)) {
return fs.readJSON(fileToUse).catch(() => defaultReturn)
} else {
try {
const importedFile = await import(fileToUse)
const adapters = preferDefault(importedFile)
return adapters
} catch (e) {
// no-op
return defaultReturn
}
}
}
Expand Down

0 comments on commit d1e6aea

Please sign in to comment.