-
Notifications
You must be signed in to change notification settings - Fork 759
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[C3] fix: make sure that all C3 projects include in their `.gitignore…
…` the wrangler files (#5129) --------- Co-authored-by: Pete Bacon Darwin <[email protected]>
- Loading branch information
1 parent
040be5d
commit 23074c7
Showing
6 changed files
with
329 additions
and
7 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,7 @@ | ||
--- | ||
"create-cloudflare": patch | ||
--- | ||
|
||
fix: make sure that all C3 projects include in their `.gitignore` the wrangler files | ||
|
||
Previously only the worker templates included in their `.gitignore` the wrangler files (those being `.dev.vars` and `.wrangler`). Make sure to instead include such files in the `.gitignore` files of all the templates including the full stack ones. |
242 changes: 242 additions & 0 deletions
242
packages/create-cloudflare/src/__tests__/templates.test.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,242 @@ | ||
import { existsSync, statSync } from "fs"; | ||
import { | ||
appendFile, | ||
directoryExists, | ||
readFile, | ||
writeFile, | ||
} from "helpers/files"; | ||
import { beforeAll, beforeEach, describe, expect, test, vi } from "vitest"; | ||
import { addWranglerToGitIgnore } from "../templates"; | ||
import type { PathLike } from "fs"; | ||
import type { C3Context } from "types"; | ||
|
||
vi.mock("fs"); | ||
vi.mock("helpers/files"); | ||
|
||
describe("addWranglerToGitIgnore", () => { | ||
const writeFileResults: { | ||
file: string | undefined; | ||
content: string | undefined; | ||
} = { file: undefined, content: undefined }; | ||
const appendFileResults: { | ||
file: string | undefined; | ||
content: string | undefined; | ||
} = { file: undefined, content: undefined }; | ||
|
||
beforeAll(() => { | ||
vi.mocked(writeFile).mockImplementation((file: string, content: string) => { | ||
writeFileResults.file = file; | ||
writeFileResults.content = content; | ||
}); | ||
vi.mocked(appendFile).mockImplementation( | ||
(file: string, content: string) => { | ||
appendFileResults.file = file; | ||
appendFileResults.content = content; | ||
} | ||
); | ||
}); | ||
|
||
beforeEach(() => { | ||
vi.mocked(statSync).mockImplementation( | ||
// eslint-disable-next-line @typescript-eslint/ban-ts-comment | ||
// @ts-ignore | ||
(path: string) => ({ | ||
isDirectory() { | ||
return path.endsWith(".git"); | ||
}, | ||
}) | ||
); | ||
vi.mocked(existsSync).mockReset(); | ||
vi.mocked(readFile).mockReset(); | ||
vi.mocked(directoryExists).mockReset(); | ||
appendFileResults.file = undefined; | ||
appendFileResults.content = undefined; | ||
writeFileResults.file = undefined; | ||
writeFileResults.content = undefined; | ||
}); | ||
|
||
test("should append the wrangler section to a standard gitignore file", () => { | ||
mockGitIgnore( | ||
"my-project/.gitignore", | ||
` | ||
node_modules | ||
.vscode` | ||
); | ||
addWranglerToGitIgnore({ | ||
project: { path: "my-project" }, | ||
} as unknown as C3Context); | ||
|
||
expect(appendFileResults.file).toMatchInlineSnapshot( | ||
`"my-project/.gitignore"` | ||
); | ||
expect(appendFileResults.content).toMatchInlineSnapshot(` | ||
" | ||
# wrangler files | ||
.wrangler | ||
.dev.vars | ||
" | ||
`); | ||
}); | ||
|
||
test("should not touch the gitignore file if it already contains all wrangler files", () => { | ||
mockGitIgnore( | ||
"my-project/.gitignore", | ||
` | ||
node_modules | ||
.dev.vars | ||
.vscode | ||
.wrangler | ||
` | ||
); | ||
addWranglerToGitIgnore({ | ||
project: { path: "my-project" }, | ||
} as unknown as C3Context); | ||
|
||
expect(appendFileResults.file).toBeUndefined(); | ||
expect(appendFileResults.content).toBeUndefined(); | ||
}); | ||
|
||
test("should not touch the gitignore file if contains all wrangler files (and can cope with comments)", () => { | ||
mockGitIgnore( | ||
"my-project/.gitignore", | ||
` | ||
node_modules | ||
.wrangler # This is for wrangler | ||
.dev.vars # this is for wrangler and getPlatformProxy | ||
.vscode | ||
` | ||
); | ||
addWranglerToGitIgnore({ | ||
project: { path: "my-project" }, | ||
} as unknown as C3Context); | ||
|
||
expect(appendFileResults.file).toBeUndefined(); | ||
expect(appendFileResults.content).toBeUndefined(); | ||
}); | ||
|
||
test("should append to the gitignore file the missing wrangler files when some is already present (without including the section heading)", () => { | ||
mockGitIgnore( | ||
"my-project/.gitignore", | ||
` | ||
node_modules | ||
.dev.vars | ||
.vscode` | ||
); | ||
addWranglerToGitIgnore({ | ||
project: { path: "my-project" }, | ||
} as unknown as C3Context); | ||
|
||
expect(appendFileResults.file).toMatchInlineSnapshot( | ||
`"my-project/.gitignore"` | ||
); | ||
expect(appendFileResults.content).toMatchInlineSnapshot(` | ||
" | ||
.wrangler | ||
" | ||
`); | ||
}); | ||
|
||
test("when it appends to the gitignore file it doesn't include an empty line only if there was one already", () => { | ||
mockGitIgnore( | ||
"my-project/.gitignore", | ||
` | ||
node_modules | ||
.dev.vars | ||
.vscode | ||
` | ||
); | ||
addWranglerToGitIgnore({ | ||
project: { path: "my-project" }, | ||
} as unknown as C3Context); | ||
|
||
expect(appendFileResults.file).toMatchInlineSnapshot( | ||
`"my-project/.gitignore"` | ||
); | ||
expect(appendFileResults.content).toMatchInlineSnapshot(` | ||
" | ||
.wrangler | ||
" | ||
`); | ||
}); | ||
|
||
test("should create the gitignore file if it didn't exist already", () => { | ||
// let's mock a gitignore file to be read by readFile | ||
mockGitIgnore("my-project/.gitignore", ""); | ||
// but let's pretend that it doesn't exist | ||
vi.mocked(existsSync).mockImplementation(() => false); | ||
// let's also pretend that the .git directory exists | ||
vi.mocked(directoryExists).mockImplementation(() => true); | ||
|
||
addWranglerToGitIgnore({ | ||
project: { path: "my-project" }, | ||
} as unknown as C3Context); | ||
|
||
// writeFile wrote the (empty) gitignore file | ||
expect(writeFileResults.file).toMatchInlineSnapshot( | ||
`"my-project/.gitignore"` | ||
); | ||
expect(writeFileResults.content).toMatchInlineSnapshot(`""`); | ||
|
||
// and the correct lines were then added to it | ||
expect(appendFileResults.file).toMatchInlineSnapshot( | ||
`"my-project/.gitignore"` | ||
); | ||
expect(appendFileResults.content).toMatchInlineSnapshot(` | ||
" | ||
# wrangler files | ||
.wrangler | ||
.dev.vars | ||
" | ||
`); | ||
}); | ||
|
||
test("should not create the gitignore file the project doesn't use git", () => { | ||
// no .gitignore file exists | ||
vi.mocked(existsSync).mockImplementation(() => false); | ||
// neither a .git directory does | ||
vi.mocked(directoryExists).mockImplementation(() => false); | ||
|
||
addWranglerToGitIgnore({ | ||
project: { path: "my-project" }, | ||
} as unknown as C3Context); | ||
|
||
expect(writeFileResults.file).toBeUndefined(); | ||
expect(writeFileResults.content).toBeUndefined(); | ||
}); | ||
|
||
test("should not add the .wrangler entry if a .wrangler/ is already included)", () => { | ||
mockGitIgnore( | ||
"my-project/.gitignore", | ||
` | ||
node_modules | ||
.wrangler/ # This is for wrangler | ||
.vscode | ||
` | ||
); | ||
addWranglerToGitIgnore({ | ||
project: { path: "my-project" }, | ||
} as unknown as C3Context); | ||
|
||
expect(appendFileResults.file).toMatchInlineSnapshot( | ||
`"my-project/.gitignore"` | ||
); | ||
expect(appendFileResults.content).toMatchInlineSnapshot(` | ||
" | ||
.dev.vars | ||
" | ||
`); | ||
}); | ||
|
||
function mockGitIgnore(path: string, content: string) { | ||
vi.mocked(existsSync).mockImplementation( | ||
(filePath: PathLike) => filePath === path | ||
); | ||
vi.mocked(readFile).mockImplementation((filePath: string) => | ||
filePath === path ? content.replace(/\n\s*/g, "\n") : "" | ||
); | ||
} | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -165,8 +165,3 @@ dist | |
.yarn/build-state.yml | ||
.yarn/install-state.gz | ||
.pnp.\* | ||
|
||
# wrangler project | ||
|
||
.dev.vars | ||
.wrangler/ |