forked from welovedevs/react-ultimate-resume
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpublish.js
238 lines (220 loc) · 8.99 KB
/
publish.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
const util = require('util');
const exec = util.promisify(require('child_process').exec);
const fs = require('fs');
const yargs = require('yargs').argv;
const rl = require('readline-sync');
const ora = require('ora');
const rimraf = require('rimraf');
require('colors');
let semver = yargs.version || 'patch';
const isVerbose = yargs.verbose === 'true' || yargs.verbose === true;
const cleanInput = ({ stdout, stderr }) => ({ stdout: stdout.replace(/\n/g, ''), stderr: stderr.replace(/\n/g, '') });
const TO_PRESERVE_DURING_CLEAN_UP = ['package.json', '.git', '.gitignore', 'node_modules'];
const TO_CHECKOUT_FROM_MASTER = ['.babelrc', '.gitignore', 'src', 'package.json'];
const VALID_SEMVER = ['patch', 'minor', 'major', 'prepatch', 'preminor', 'premajor', 'prerelease'];
const run = async () => {
if (isVerbose) {
console.log('ℹ Starting publishing package in verbose mode.');
}
semverIndex = rl.keyInSelect(VALID_SEMVER, 'ℹ What kind of build is it?');
if (semverIndex === -1) {
process.exit(-1);
}
semver = VALID_SEMVER[semverIndex];
const checkMasterSpinner = ora('Checking current branch...').start();
const checkMaster = await exec('git rev-parse --abbrev-ref HEAD').then(cleanInput);
if (checkMaster.stdout !== 'master') {
checkMasterSpinner.fail('Cannot create version when not on master.');
process.exit(-1);
}
checkMasterSpinner.succeed('Current branch is master.');
const filesResultSpinner = ora('Checking for modified files...');
const lsFilesResult = await exec('git ls-files -m');
if (lsFilesResult.stdout) {
filesResultSpinner.fail('Cannot create version with modified files. Commit or stash them.');
process.exit(-1);
}
filesResultSpinner.succeed('No modified files found.');
const upgradingVersionSpinner = ora('Bumping package version...').start();
try {
await exec(`npm version ${semver} --no-git-tag-version`);
} catch (error) {
upgradingVersionSpinner.fail('Could not bump version.');
if (isVerbose) {
console.error(error);
}
process.exit(-1);
}
const packageFile = fs.readFileSync('package.json');
const { version } = JSON.parse(packageFile);
upgradingVersionSpinner.succeed(`Bumped version to ${version}.`);
const commitMasterNewVersionSpinner = ora('Committing new version on local master branch...').start();
try {
await exec(`git commit -am 'Bump version to ${version}'.`);
} catch (error) {
commitMasterNewVersionSpinner.fail('Could not commit new version on local master branch.');
if (isVerbose) {
console.error(error);
}
process.exit(-1);
}
commitMasterNewVersionSpinner.succeed('Created new version commit on local master branch.');
const createBuildBranchSpinner = ora('Trying to create build branch.').start();
try {
await exec('git branch build');
createBuildBranchSpinner.succeed('Created build branch.');
} catch {
createBuildBranchSpinner.info('Branch build already exists.');
}
const checkingOutBuildBranchSpinner = ora('Checking out build branch...').start();
try {
await exec('git checkout build');
} catch (error) {
checkingOutBuildBranchSpinner.fail('Could not checkout build branch.');
if (isVerbose) {
console.error(error);
}
process.exit(-1);
}
checkingOutBuildBranchSpinner.succeed('Checked out build branch.');
const pullingBuildBranchSpinner = ora('Pulling remote branch and fetching latest version.').start();
try {
await exec('git fetch');
await exec('git reset --hard origin/build');
pullingBuildBranchSpinner.succeed('Pulled remote branch.');
} catch {
pullingBuildBranchSpinner.info('Could not pull remote branch, might not have been pushed yet.');
}
const cleanBuildBranchSpinner = ora('Cleaning build branch...').start();
let rootFiles = fs.readdirSync(__dirname);
if (rootFiles && rootFiles.length) {
rootFiles = rootFiles.filter(name => !TO_PRESERVE_DURING_CLEAN_UP.includes(name));
cleanBuildBranchSpinner.text = `Cleaning build branch... (Removing ${rootFiles.length} element${
rootFiles.length > 1 ? 's' : ''
})...`;
rootFiles.forEach((name, index) => {
cleanBuildBranchSpinner.text = `Cleaning build branch... (Removing ${rootFiles.length} element${
rootFiles.length > 1 ? 's' : ''
}) (${index + 1} / ${rootFiles.length})...`;
rimraf.sync(__dirname + `/${name}`, {}, () => {});
});
}
cleanBuildBranchSpinner.succeed('Cleaned build branch.');
const mergingMasterSourcesSpinner = ora('Checking out master elements...').start();
try {
await exec(`git checkout --theirs master ${TO_CHECKOUT_FROM_MASTER.join(' ')}`);
} catch (error) {
mergingMasterSourcesSpinner.fail('Could not check out master elements.');
if (isVerbose) {
console.error(error);
}
process.exit(-1);
}
mergingMasterSourcesSpinner.succeed('Checked out master elements.');
const srcPath = __dirname + '/src/package';
const srcFiles = fs.readdirSync(srcPath);
if (!srcFiles || !srcFiles.length) {
error('⨯ Did not find any sources. Exiting.');
process.exit(-1);
}
const installSpinner = ora('Installing dependencies...').start();
try {
await exec('npm install');
} catch (error) {
installSpinner.fail('Dependencies installation failed.');
if (isVerbose) {
console.error(error);
}
process.exit(-1);
}
installSpinner.succeed('Dependencies installed.');
const buildingPackageSpinner = ora(`Building fresh package...`).start();
try {
await exec('npm run package');
} catch (error) {
buildingPackageSpinner.fail('Package build failed.');
if (isVerbose) {
console.error(error);
}
process.exit(-1);
}
buildingPackageSpinner.succeed('Package built.');
const postBuildCleanUpSpinner = ora('Doing post-build clean-up...').start();
const rootNewFiles = fs.readdirSync(__dirname);
rootNewFiles
.filter(name => !srcFiles.includes(name) && !TO_PRESERVE_DURING_CLEAN_UP.includes(name))
.forEach(fileName => {
rimraf.sync(__dirname + `/${fileName}`, {}, () => {});
});
postBuildCleanUpSpinner.succeed('Did post-build clean up.');
const committingNewBuildSpinner = ora('Committing freshly made package build...').start();
try {
await exec('git add --all');
await exec(`git commit --no-verify --allow-empty -am "New version build : ${version}."`);
} catch (error) {
committingNewBuildSpinner.fail('Could not commit new package build.');
if (isVerbose) {
console.error(error);
}
process.exit(-1);
}
committingNewBuildSpinner.succeed('Committed new package build.');
const creatingNewVersionTagSpinner = ora('Creating new version tag...').start();
try {
await exec(`git tag v${version}`);
} catch (error) {
creatingNewVersionTagSpinner.fail('Could not create new version tag.');
if (isVerbose) {
console.error(error);
}
process.exit(-1);
}
creatingNewVersionTagSpinner.succeed('Created new version tag.');
const pushingBuildBranchSpinner = ora('Pushing local build branch...').start();
try {
await exec(`git push origin build`);
} catch (error) {
pushingBuildBranchSpinner.fail('Could not push local build branch.');
if (isVerbose) {
console.error(error);
}
process.exit(-1);
}
pushingBuildBranchSpinner.succeed('Pushed local build branch.');
const pushingTagsSpinner = ora(`Publishing version ${version}...`).start();
try {
await exec(`git push --tags`);
} catch (error) {
pushingTagsSpinner.fail(`Could not publish new version ${version}.`);
if (isVerbose) {
console.error(error);
}
process.exit(-1);
}
pushingTagsSpinner.succeed(`Published version ${version}.`);
const checkingOutMasterSpinner = ora('Checking out master branch...');
try {
await exec(`git checkout master`);
} catch (error) {
checkingOutMasterSpinner.fail('Could not check out master.');
if (isVerbose) {
console.error(error);
}
process.exit(-1);
}
checkingOutMasterSpinner.succeed('Checked out master.');
const pushingMasterSpinner = ora('Pushing local master branch...').start();
try {
await exec(`git push origin master`);
} catch (error) {
pushingMasterSpinner.fail('Could not push local master branch.');
if (isVerbose) {
console.error(error);
}
process.exit(-1);
}
pushingMasterSpinner.succeed('Pushed local master branch.');
console.log('\n✅ Package published successfully.');
process.exit(0);
};
run();