npm-update-package 0.36.0 → 0.37.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/dist/package.json +1 -1
- package/dist/src/github/GitHub.js +16 -0
- package/dist/src/github/index.js +1 -0
- package/dist/src/github/pull-request/creator/PullRequestBodyCreator.js +103 -0
- package/dist/src/github/pull-request/creator/PullRequestCreator.js +3 -3
- package/dist/src/github/pull-request/creator/index.js +1 -0
- package/dist/src/github/releases/fetcher/ReleasesFetcher.js +18 -0
- package/dist/src/github/releases/fetcher/index.js +13 -0
- package/dist/src/github/releases/index.js +13 -0
- package/dist/src/main.js +5 -0
- package/package.json +1 -1
- package/dist/src/github/pull-request/creator/createPullRequestBody.js +0 -62
package/dist/package.json
CHANGED
|
@@ -75,6 +75,22 @@ class GitHub {
|
|
|
75
75
|
});
|
|
76
76
|
return data;
|
|
77
77
|
}
|
|
78
|
+
async fetchReleases({ owner, repo }) {
|
|
79
|
+
const releases = [];
|
|
80
|
+
for (let page = 1;; page++) {
|
|
81
|
+
const { data } = await this.octokit.repos.listReleases({
|
|
82
|
+
owner,
|
|
83
|
+
repo,
|
|
84
|
+
per_page: 100,
|
|
85
|
+
page
|
|
86
|
+
});
|
|
87
|
+
if (data.length === 0) {
|
|
88
|
+
break;
|
|
89
|
+
}
|
|
90
|
+
releases.push(...data);
|
|
91
|
+
}
|
|
92
|
+
return releases;
|
|
93
|
+
}
|
|
78
94
|
async fetchRepository({ owner, repo }) {
|
|
79
95
|
const { data } = await this.octokit.repos.get({
|
|
80
96
|
owner,
|
package/dist/src/github/index.js
CHANGED
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.PullRequestBodyCreator = void 0;
|
|
7
|
+
const package_json_1 = __importDefault(require("../../../../package.json"));
|
|
8
|
+
const file_1 = require("../../../file");
|
|
9
|
+
const json_1 = require("../../../json");
|
|
10
|
+
const package_json_2 = require("../../../package-json");
|
|
11
|
+
const metadata_1 = require("../metadata");
|
|
12
|
+
class PullRequestBodyCreator {
|
|
13
|
+
constructor({ releasesFetcher }) {
|
|
14
|
+
this.releasesFetcher = releasesFetcher;
|
|
15
|
+
}
|
|
16
|
+
async create(outdatedPackage) {
|
|
17
|
+
const gitRepo = await this.extractRepository(outdatedPackage);
|
|
18
|
+
const outdatedPackagesTable = this.createOutdatedPackagesTable({
|
|
19
|
+
outdatedPackage,
|
|
20
|
+
gitRepo
|
|
21
|
+
});
|
|
22
|
+
const metadataSection = this.createMetadataSection(outdatedPackage);
|
|
23
|
+
const footer = this.createFooter();
|
|
24
|
+
if (gitRepo === undefined) {
|
|
25
|
+
return `This PR updates these packages:
|
|
26
|
+
|
|
27
|
+
${outdatedPackagesTable}
|
|
28
|
+
|
|
29
|
+
---
|
|
30
|
+
${metadataSection}
|
|
31
|
+
|
|
32
|
+
---
|
|
33
|
+
${footer}`;
|
|
34
|
+
}
|
|
35
|
+
const releaseNotesSection = await this.createReleaseNotesSection({
|
|
36
|
+
outdatedPackage,
|
|
37
|
+
gitRepo
|
|
38
|
+
});
|
|
39
|
+
return `This PR updates these packages:
|
|
40
|
+
|
|
41
|
+
${outdatedPackagesTable}
|
|
42
|
+
|
|
43
|
+
${releaseNotesSection}
|
|
44
|
+
|
|
45
|
+
---
|
|
46
|
+
${metadataSection}
|
|
47
|
+
|
|
48
|
+
---
|
|
49
|
+
${footer}`;
|
|
50
|
+
}
|
|
51
|
+
async extractRepository(outdatedPackage) {
|
|
52
|
+
const packageJson = await (0, file_1.readFile)(`node_modules/${outdatedPackage.name}/package.json`);
|
|
53
|
+
const pkg = (0, package_json_2.parsePackageJson)(packageJson);
|
|
54
|
+
return (0, package_json_2.extractRepository)(pkg);
|
|
55
|
+
}
|
|
56
|
+
async createReleaseNotesSection({ outdatedPackage, gitRepo }) {
|
|
57
|
+
const releases = await this.releasesFetcher.fetch({
|
|
58
|
+
gitRepo,
|
|
59
|
+
from: outdatedPackage.currentVersion,
|
|
60
|
+
to: outdatedPackage.newVersion
|
|
61
|
+
});
|
|
62
|
+
const items = releases.map(release => `- [${release.tag_name}](${release.html_url})`);
|
|
63
|
+
return `## Release notes
|
|
64
|
+
|
|
65
|
+
${items.join('\n')}`;
|
|
66
|
+
}
|
|
67
|
+
createOutdatedPackagesTable({ outdatedPackage, gitRepo }) {
|
|
68
|
+
const packageName = outdatedPackage.name;
|
|
69
|
+
const packageLink = `[${packageName}](https://www.npmjs.com/package/${packageName})`;
|
|
70
|
+
const repositoryLink = gitRepo !== undefined ? `[${gitRepo.owner}/${gitRepo.name}](${gitRepo.url.toString()})` : '-';
|
|
71
|
+
const level = outdatedPackage.level;
|
|
72
|
+
const currentVersion = outdatedPackage.currentVersion.version;
|
|
73
|
+
const currentVersionLink = `[\`${currentVersion}\`](https://www.npmjs.com/package/${packageName}/v/${currentVersion})`;
|
|
74
|
+
const newVersion = outdatedPackage.newVersion.version;
|
|
75
|
+
const newVersionLink = `[\`${newVersion}\`](https://www.npmjs.com/package/${packageName}/v/${newVersion})`;
|
|
76
|
+
const diffLink = `[diff](https://renovatebot.com/diffs/npm/${packageName}/${currentVersion}/${newVersion})`;
|
|
77
|
+
const version = `${currentVersionLink} -> ${newVersionLink} (${diffLink})`;
|
|
78
|
+
return `|Package|Repository|Level|Version|
|
|
79
|
+
|---|---|---|---|
|
|
80
|
+
|${packageLink}|${repositoryLink}|${level}|${version}|`;
|
|
81
|
+
}
|
|
82
|
+
createMetadataSection(outdatedPackage) {
|
|
83
|
+
const metadata = (0, metadata_1.createPullRequestMetadata)([outdatedPackage]);
|
|
84
|
+
const json = (0, json_1.toJSON)(metadata, { pretty: true });
|
|
85
|
+
return `<details>
|
|
86
|
+
<summary>Metadata</summary>
|
|
87
|
+
|
|
88
|
+
**Don't remove or edit this section because it will be used by npm-update-package.**
|
|
89
|
+
|
|
90
|
+
<div id="npm-update-package-metadata">
|
|
91
|
+
|
|
92
|
+
\`\`\`json
|
|
93
|
+
${json}
|
|
94
|
+
\`\`\`
|
|
95
|
+
|
|
96
|
+
</div>
|
|
97
|
+
</details>`;
|
|
98
|
+
}
|
|
99
|
+
createFooter() {
|
|
100
|
+
return `This PR has been generated by [${package_json_1.default.name}](${package_json_1.default.homepage}) v${package_json_1.default.version}`;
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
exports.PullRequestBodyCreator = PullRequestBodyCreator;
|
|
@@ -1,20 +1,20 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.PullRequestCreator = void 0;
|
|
4
|
-
const createPullRequestBody_1 = require("./createPullRequestBody");
|
|
5
4
|
class PullRequestCreator {
|
|
6
|
-
constructor({ github, gitRepo, githubRepo, pullRequestTitleCreator, logger, reviewers }) {
|
|
5
|
+
constructor({ github, gitRepo, githubRepo, pullRequestTitleCreator, pullRequestBodyCreator, logger, reviewers }) {
|
|
7
6
|
this.github = github;
|
|
8
7
|
this.gitRepo = gitRepo;
|
|
9
8
|
this.githubRepo = githubRepo;
|
|
10
9
|
this.pullRequestTitleCreator = pullRequestTitleCreator;
|
|
10
|
+
this.pullRequestBodyCreator = pullRequestBodyCreator;
|
|
11
11
|
this.logger = logger;
|
|
12
12
|
this.reviewers = reviewers;
|
|
13
13
|
}
|
|
14
14
|
async create({ outdatedPackage, branchName }) {
|
|
15
15
|
const title = this.pullRequestTitleCreator.create(outdatedPackage);
|
|
16
16
|
this.logger.debug(`title=${title}`);
|
|
17
|
-
const body = await
|
|
17
|
+
const body = await this.pullRequestBodyCreator.create(outdatedPackage);
|
|
18
18
|
this.logger.debug(`body=${body}`);
|
|
19
19
|
const pullRequest = await this.github.createPullRequest({
|
|
20
20
|
owner: this.gitRepo.owner,
|
|
@@ -10,5 +10,6 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
10
10
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
11
11
|
};
|
|
12
12
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
|
+
__exportStar(require("./PullRequestBodyCreator"), exports);
|
|
13
14
|
__exportStar(require("./PullRequestCreator"), exports);
|
|
14
15
|
__exportStar(require("./PullRequestTitleCreator"), exports);
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ReleasesFetcher = void 0;
|
|
4
|
+
const semver_1 = require("semver");
|
|
5
|
+
// TODO: Add test
|
|
6
|
+
class ReleasesFetcher {
|
|
7
|
+
constructor(github) {
|
|
8
|
+
this.github = github;
|
|
9
|
+
}
|
|
10
|
+
async fetch({ gitRepo, from, to }) {
|
|
11
|
+
const releases = await this.github.fetchReleases({
|
|
12
|
+
owner: gitRepo.owner,
|
|
13
|
+
repo: gitRepo.name
|
|
14
|
+
});
|
|
15
|
+
return releases.filter(({ tag_name: version }) => (0, semver_1.gte)(version, from.version) && (0, semver_1.lte)(version, to.version));
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
exports.ReleasesFetcher = ReleasesFetcher;
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
|
5
|
+
}) : (function(o, m, k, k2) {
|
|
6
|
+
if (k2 === undefined) k2 = k;
|
|
7
|
+
o[k2] = m[k];
|
|
8
|
+
}));
|
|
9
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
10
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
11
|
+
};
|
|
12
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
|
+
__exportStar(require("./ReleasesFetcher"), exports);
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
|
5
|
+
}) : (function(o, m, k, k2) {
|
|
6
|
+
if (k2 === undefined) k2 = k;
|
|
7
|
+
o[k2] = m[k];
|
|
8
|
+
}));
|
|
9
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
10
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
11
|
+
};
|
|
12
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
|
+
__exportStar(require("./fetcher"), exports);
|
package/dist/src/main.js
CHANGED
|
@@ -61,11 +61,16 @@ const main = async ({ options, logger }) => {
|
|
|
61
61
|
packageManager: options.packageManager
|
|
62
62
|
});
|
|
63
63
|
const pullRequestTitleCreator = new github_1.PullRequestTitleCreator(options.pullRequestTitle);
|
|
64
|
+
const releasesFetcher = new github_1.ReleasesFetcher(github);
|
|
65
|
+
const pullRequestBodyCreator = new github_1.PullRequestBodyCreator({
|
|
66
|
+
releasesFetcher
|
|
67
|
+
});
|
|
64
68
|
const pullRequestCreator = new github_1.PullRequestCreator({
|
|
65
69
|
github,
|
|
66
70
|
gitRepo,
|
|
67
71
|
githubRepo,
|
|
68
72
|
pullRequestTitleCreator,
|
|
73
|
+
pullRequestBodyCreator,
|
|
69
74
|
logger,
|
|
70
75
|
reviewers: options.reviewers
|
|
71
76
|
});
|
package/package.json
CHANGED
|
@@ -1,62 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.createPullRequestBody = void 0;
|
|
7
|
-
const package_json_1 = __importDefault(require("../../../../package.json"));
|
|
8
|
-
const file_1 = require("../../../file");
|
|
9
|
-
const json_1 = require("../../../json");
|
|
10
|
-
const package_json_2 = require("../../../package-json");
|
|
11
|
-
const metadata_1 = require("../metadata");
|
|
12
|
-
const createPullRequestBody = async (outdatedPackage) => {
|
|
13
|
-
const packageJson = await (0, file_1.readFile)(`node_modules/${outdatedPackage.name}/package.json`);
|
|
14
|
-
const pkg = (0, package_json_2.parsePackageJson)(packageJson);
|
|
15
|
-
const repository = (0, package_json_2.extractRepository)(pkg);
|
|
16
|
-
const outdatedPackagesTable = createOutdatedPackagesTable({
|
|
17
|
-
outdatedPackage,
|
|
18
|
-
repository
|
|
19
|
-
});
|
|
20
|
-
const metadataSection = createMetadataSection(outdatedPackage);
|
|
21
|
-
return `This PR updates these packages:
|
|
22
|
-
|
|
23
|
-
${outdatedPackagesTable}
|
|
24
|
-
|
|
25
|
-
${metadataSection}
|
|
26
|
-
|
|
27
|
-
---
|
|
28
|
-
This PR has been generated by [${package_json_1.default.name}](${package_json_1.default.homepage}) v${package_json_1.default.version}`;
|
|
29
|
-
};
|
|
30
|
-
exports.createPullRequestBody = createPullRequestBody;
|
|
31
|
-
const createOutdatedPackagesTable = ({ outdatedPackage, repository }) => {
|
|
32
|
-
const packageName = outdatedPackage.name;
|
|
33
|
-
const packageLink = `[${packageName}](https://www.npmjs.com/package/${packageName})`;
|
|
34
|
-
const repositoryLink = repository !== undefined ? `[${repository.owner}/${repository.name}](${repository.url.toString()})` : '-';
|
|
35
|
-
const level = outdatedPackage.level;
|
|
36
|
-
const currentVersion = outdatedPackage.currentVersion.version;
|
|
37
|
-
const currentVersionLink = `[\`${currentVersion}\`](https://www.npmjs.com/package/${packageName}/v/${currentVersion})`;
|
|
38
|
-
const newVersion = outdatedPackage.newVersion.version;
|
|
39
|
-
const newVersionLink = `[\`${newVersion}\`](https://www.npmjs.com/package/${packageName}/v/${newVersion})`;
|
|
40
|
-
const diffLink = `[diff](https://renovatebot.com/diffs/npm/${packageName}/${currentVersion}/${newVersion})`;
|
|
41
|
-
const version = `${currentVersionLink} -> ${newVersionLink} (${diffLink})`;
|
|
42
|
-
return `|Package|Repository|Level|Version|
|
|
43
|
-
|---|---|---|---|
|
|
44
|
-
|${packageLink}|${repositoryLink}|${level}|${version}|`;
|
|
45
|
-
};
|
|
46
|
-
const createMetadataSection = (outdatedPackage) => {
|
|
47
|
-
const metadata = (0, metadata_1.createPullRequestMetadata)([outdatedPackage]);
|
|
48
|
-
const json = (0, json_1.toJSON)(metadata, { pretty: true });
|
|
49
|
-
return `<details>
|
|
50
|
-
<summary>Metadata</summary>
|
|
51
|
-
|
|
52
|
-
**Don't remove or edit this section because it will be used by npm-update-package.**
|
|
53
|
-
|
|
54
|
-
<div id="npm-update-package-metadata">
|
|
55
|
-
|
|
56
|
-
\`\`\`json
|
|
57
|
-
${json}
|
|
58
|
-
\`\`\`
|
|
59
|
-
|
|
60
|
-
</div>
|
|
61
|
-
</details>`;
|
|
62
|
-
};
|