create-platformatic 0.11.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.taprc +1 -0
- package/LICENSE +201 -0
- package/NOTICE +13 -0
- package/README.md +13 -0
- package/create-platformatic.mjs +31 -0
- package/help/db.txt +11 -0
- package/help/help.txt +8 -0
- package/help/service.txt +7 -0
- package/package.json +47 -0
- package/src/ask-project-dir.mjs +18 -0
- package/src/colors.mjs +4 -0
- package/src/create-gitignore.mjs +34 -0
- package/src/create-package-json.mjs +32 -0
- package/src/db/README.md +38 -0
- package/src/db/create-db-cli.mjs +174 -0
- package/src/db/create-db.mjs +200 -0
- package/src/get-pkg-manager.mjs +11 -0
- package/src/ghaction.mjs +68 -0
- package/src/index.mjs +51 -0
- package/src/say.mjs +20 -0
- package/src/service/README.md +31 -0
- package/src/service/create-service-cli.mjs +88 -0
- package/src/service/create-service.mjs +94 -0
- package/src/utils.mjs +95 -0
- package/test/create-gitignore.test.mjs +35 -0
- package/test/create-package-json.test.mjs +56 -0
- package/test/db/create-db.test.mjs +241 -0
- package/test/get-pkg-manager.test.mjs +36 -0
- package/test/ghaction.test.mjs +62 -0
- package/test/service/create-service.test.mjs +88 -0
- package/test/utils.test.mjs +182 -0
|
@@ -0,0 +1,182 @@
|
|
|
1
|
+
import { test, beforeEach } from 'tap'
|
|
2
|
+
import { MockAgent, setGlobalDispatcher } from 'undici'
|
|
3
|
+
import { getVersion, randomBetween, sleep, validatePath, getDependencyVersion, findDBConfigFile, findServiceConfigFile, isFileAccessible } from '../src/utils.mjs'
|
|
4
|
+
import { mkdtempSync, rmSync, writeFileSync } from 'fs'
|
|
5
|
+
import { tmpdir } from 'os'
|
|
6
|
+
import { join } from 'path'
|
|
7
|
+
import esmock from 'esmock'
|
|
8
|
+
import semver from 'semver'
|
|
9
|
+
|
|
10
|
+
let mockAgent
|
|
11
|
+
|
|
12
|
+
beforeEach(() => {
|
|
13
|
+
mockAgent = new MockAgent()
|
|
14
|
+
setGlobalDispatcher(mockAgent)
|
|
15
|
+
mockAgent.disableNetConnect()
|
|
16
|
+
})
|
|
17
|
+
|
|
18
|
+
test('getUsername from git', async ({ end, equal }) => {
|
|
19
|
+
const name = 'lukeskywalker'
|
|
20
|
+
const { getUsername } = await esmock.strict('../src/utils.mjs', {
|
|
21
|
+
execa: {
|
|
22
|
+
execa: (command) => {
|
|
23
|
+
if (command === 'git') {
|
|
24
|
+
return { stdout: name }
|
|
25
|
+
}
|
|
26
|
+
return ''
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
})
|
|
30
|
+
const username = await getUsername()
|
|
31
|
+
equal(username, name)
|
|
32
|
+
})
|
|
33
|
+
|
|
34
|
+
test('getUsername from whoami', async ({ end, equal }) => {
|
|
35
|
+
const name = 'hansolo'
|
|
36
|
+
const { getUsername } = await esmock.strict('../src/utils.mjs', {
|
|
37
|
+
execa: {
|
|
38
|
+
execa: (command) => {
|
|
39
|
+
if (command === 'whoami') {
|
|
40
|
+
return { stdout: name }
|
|
41
|
+
}
|
|
42
|
+
return ''
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
})
|
|
46
|
+
const username = await getUsername()
|
|
47
|
+
equal(username, name)
|
|
48
|
+
})
|
|
49
|
+
|
|
50
|
+
test('getUsername - no username found', async ({ end, equal }) => {
|
|
51
|
+
const { getUsername } = await esmock.strict('../src/utils.mjs', {
|
|
52
|
+
execa: {
|
|
53
|
+
execa: (command) => {
|
|
54
|
+
return ''
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
})
|
|
58
|
+
const username = await getUsername()
|
|
59
|
+
equal(username, null)
|
|
60
|
+
})
|
|
61
|
+
|
|
62
|
+
test('Get the version', async ({ end, equal, mock }) => {
|
|
63
|
+
const client = mockAgent.get('https://registry.npmjs.org')
|
|
64
|
+
const version = 'v1.2.3'
|
|
65
|
+
|
|
66
|
+
client
|
|
67
|
+
.intercept({
|
|
68
|
+
path: '/platformatic/latest',
|
|
69
|
+
method: 'GET'
|
|
70
|
+
})
|
|
71
|
+
.reply(200, {
|
|
72
|
+
version
|
|
73
|
+
})
|
|
74
|
+
const versionFromNPM = await getVersion()
|
|
75
|
+
equal(versionFromNPM, version)
|
|
76
|
+
})
|
|
77
|
+
|
|
78
|
+
test('Get the version as `null` if something goes wrong ', async ({ end, equal, mock }) => {
|
|
79
|
+
const client = mockAgent.get('https://registry.npmjs.org')
|
|
80
|
+
const version = 'v1.2.3'
|
|
81
|
+
client
|
|
82
|
+
.intercept({
|
|
83
|
+
path: '/platformatic/latest',
|
|
84
|
+
method: 'GET'
|
|
85
|
+
})
|
|
86
|
+
.reply(500, {
|
|
87
|
+
version
|
|
88
|
+
})
|
|
89
|
+
const versionFromNPM = await getVersion()
|
|
90
|
+
equal(versionFromNPM, null)
|
|
91
|
+
})
|
|
92
|
+
|
|
93
|
+
test('Get the version as `null` if body has no version', async ({ end, equal, mock }) => {
|
|
94
|
+
const client = mockAgent.get('https://registry.npmjs.org')
|
|
95
|
+
client
|
|
96
|
+
.intercept({
|
|
97
|
+
path: '/platformatic/latest',
|
|
98
|
+
method: 'GET'
|
|
99
|
+
})
|
|
100
|
+
.reply(200, null)
|
|
101
|
+
const versionFromNPM = await getVersion()
|
|
102
|
+
equal(versionFromNPM, null)
|
|
103
|
+
})
|
|
104
|
+
|
|
105
|
+
test('randomBetween', async ({ end, equal }) => {
|
|
106
|
+
const min = 1
|
|
107
|
+
const max = 10
|
|
108
|
+
const random = randomBetween(min, max)
|
|
109
|
+
equal(random >= min && random <= max, true)
|
|
110
|
+
})
|
|
111
|
+
|
|
112
|
+
test('sleep', async ({ equal }) => {
|
|
113
|
+
const start = Date.now()
|
|
114
|
+
await sleep(100)
|
|
115
|
+
const end = Date.now()
|
|
116
|
+
equal(end - start >= 100, true)
|
|
117
|
+
})
|
|
118
|
+
|
|
119
|
+
test('validatePath', async ({ end, equal, rejects, ok }) => {
|
|
120
|
+
{
|
|
121
|
+
// new folder
|
|
122
|
+
const valid = await validatePath('new-project')
|
|
123
|
+
ok(valid)
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
{
|
|
127
|
+
// existing folder
|
|
128
|
+
const valid = await validatePath('test')
|
|
129
|
+
ok(valid)
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
{
|
|
133
|
+
// current folder
|
|
134
|
+
const valid = await validatePath('.')
|
|
135
|
+
ok(valid)
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
{
|
|
139
|
+
// not writeable folder
|
|
140
|
+
const valid = await validatePath('/')
|
|
141
|
+
ok(!valid)
|
|
142
|
+
}
|
|
143
|
+
})
|
|
144
|
+
|
|
145
|
+
test('getDependencyVersion', async ({ equal }) => {
|
|
146
|
+
const fastifyVersion = await getDependencyVersion('fastify')
|
|
147
|
+
// We cannot assert the exact version because it changes
|
|
148
|
+
equal(semver.valid(fastifyVersion), fastifyVersion)
|
|
149
|
+
equal(semver.gt(fastifyVersion, '4.10.0'), true)
|
|
150
|
+
})
|
|
151
|
+
|
|
152
|
+
test('findDBConfigFile', async ({ end, equal, mock }) => {
|
|
153
|
+
const tmpDir1 = mkdtempSync(join(tmpdir(), 'test-create-platformatic-'))
|
|
154
|
+
const tmpDir2 = mkdtempSync(join(tmpdir(), 'test-create-platformatic-'))
|
|
155
|
+
const config = join(tmpDir1, 'platformatic.db.yml')
|
|
156
|
+
writeFileSync(config, 'TEST')
|
|
157
|
+
equal(await findDBConfigFile(tmpDir1), 'platformatic.db.yml')
|
|
158
|
+
equal(await findDBConfigFile(tmpDir2), undefined)
|
|
159
|
+
rmSync(tmpDir1, { recursive: true, force: true })
|
|
160
|
+
rmSync(tmpDir2, { recursive: true, force: true })
|
|
161
|
+
})
|
|
162
|
+
|
|
163
|
+
test('findServiceConfigFile', async ({ end, equal, mock }) => {
|
|
164
|
+
const tmpDir1 = mkdtempSync(join(tmpdir(), 'test-create-platformatic-'))
|
|
165
|
+
const tmpDir2 = mkdtempSync(join(tmpdir(), 'test-create-platformatic-'))
|
|
166
|
+
const config = join(tmpDir1, 'platformatic.service.toml')
|
|
167
|
+
writeFileSync(config, 'TEST')
|
|
168
|
+
equal(await findServiceConfigFile(tmpDir1), 'platformatic.service.toml')
|
|
169
|
+
equal(await findServiceConfigFile(tmpDir2), undefined)
|
|
170
|
+
rmSync(tmpDir1, { recursive: true, force: true })
|
|
171
|
+
rmSync(tmpDir2, { recursive: true, force: true })
|
|
172
|
+
})
|
|
173
|
+
|
|
174
|
+
test('isFileAccessible', async ({ end, equal, mock }) => {
|
|
175
|
+
const tmpDir1 = mkdtempSync(join(tmpdir(), 'test-create-platformatic-'))
|
|
176
|
+
const config = join(tmpDir1, 'platformatic.db.yml')
|
|
177
|
+
writeFileSync(config, 'TEST')
|
|
178
|
+
equal(await isFileAccessible(config), true)
|
|
179
|
+
const config2 = join(tmpDir1, 'platformatic2.db.yml')
|
|
180
|
+
equal(await isFileAccessible(config2), false)
|
|
181
|
+
rmSync(tmpDir1, { recursive: true, force: true })
|
|
182
|
+
})
|