feat: only new issues enhancements (#1029)
This commit is contained in:
parent
692c9c9dba
commit
9d1e0624a7
10
README.md
10
README.md
@ -61,7 +61,9 @@ jobs:
|
|||||||
# The location of the configuration file can be changed by using `--config=`
|
# The location of the configuration file can be changed by using `--config=`
|
||||||
# args: --timeout=30m --config=/my/path/.golangci.yml --issues-exit-code=0
|
# args: --timeout=30m --config=/my/path/.golangci.yml --issues-exit-code=0
|
||||||
|
|
||||||
# Optional: For pull request only, show only new issues. The default value is `false`.
|
# Optional: Show only new issues.
|
||||||
|
# If you are using `merge_group` event (merge queue) you should add the option `fetch-depth: 0` to `actions/checkout` step.
|
||||||
|
# The default value is `false`.
|
||||||
# only-new-issues: true
|
# only-new-issues: true
|
||||||
|
|
||||||
# Optional: if set to true, then all caching functionality will be completely disabled,
|
# Optional: if set to true, then all caching functionality will be completely disabled,
|
||||||
@ -104,7 +106,7 @@ jobs:
|
|||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
go: ['1.21']
|
go: ['1.21']
|
||||||
os: [macos-latest, windows-latest]
|
os: [ubuntu-latest, macos-latest, windows-latest]
|
||||||
name: lint
|
name: lint
|
||||||
runs-on: ${{ matrix.os }}
|
runs-on: ${{ matrix.os }}
|
||||||
steps:
|
steps:
|
||||||
@ -129,7 +131,9 @@ jobs:
|
|||||||
# The location of the configuration file can be changed by using `--config=`
|
# The location of the configuration file can be changed by using `--config=`
|
||||||
# args: --timeout=30m --config=/my/path/.golangci.yml --issues-exit-code=0
|
# args: --timeout=30m --config=/my/path/.golangci.yml --issues-exit-code=0
|
||||||
|
|
||||||
# Optional: For pull request only, show only new issues. The default value is `false`.
|
# Optional: Show only new issues.
|
||||||
|
# If you are using `merge_group` event (merge queue) you should add the option `fetch-depth: 0` to `actions/checkout` step.
|
||||||
|
# The default value is `false`.
|
||||||
# only-new-issues: true
|
# only-new-issues: true
|
||||||
|
|
||||||
# Optional: if set to true, then all caching functionality will be completely disabled,
|
# Optional: if set to true, then all caching functionality will be completely disabled,
|
||||||
|
94
dist/post_run/index.js
generated
vendored
94
dist/post_run/index.js
generated
vendored
@ -89146,26 +89146,40 @@ const version_1 = __nccwpck_require__(1946);
|
|||||||
const execShellCommand = (0, util_1.promisify)(child_process_1.exec);
|
const execShellCommand = (0, util_1.promisify)(child_process_1.exec);
|
||||||
const writeFile = (0, util_1.promisify)(fs.writeFile);
|
const writeFile = (0, util_1.promisify)(fs.writeFile);
|
||||||
const createTempDir = (0, util_1.promisify)(tmp_1.dir);
|
const createTempDir = (0, util_1.promisify)(tmp_1.dir);
|
||||||
|
function isOnlyNewIssues() {
|
||||||
|
const onlyNewIssues = core.getInput(`only-new-issues`, { required: true }).trim();
|
||||||
|
if (onlyNewIssues !== `false` && onlyNewIssues !== `true`) {
|
||||||
|
throw new Error(`invalid value of "only-new-issues": "${onlyNewIssues}", expected "true" or "false"`);
|
||||||
|
}
|
||||||
|
return onlyNewIssues === `true`;
|
||||||
|
}
|
||||||
async function prepareLint() {
|
async function prepareLint() {
|
||||||
const mode = core.getInput("install-mode").toLowerCase();
|
const mode = core.getInput("install-mode").toLowerCase();
|
||||||
const versionConfig = await (0, version_1.findLintVersion)(mode);
|
const versionConfig = await (0, version_1.findLintVersion)(mode);
|
||||||
return await (0, install_1.installLint)(versionConfig, mode);
|
return await (0, install_1.installLint)(versionConfig, mode);
|
||||||
}
|
}
|
||||||
async function fetchPatch() {
|
async function fetchPatch() {
|
||||||
const onlyNewIssues = core.getInput(`only-new-issues`, { required: true }).trim();
|
if (!isOnlyNewIssues()) {
|
||||||
if (onlyNewIssues !== `false` && onlyNewIssues !== `true`) {
|
|
||||||
throw new Error(`invalid value of "only-new-issues": "${onlyNewIssues}", expected "true" or "false"`);
|
|
||||||
}
|
|
||||||
if (onlyNewIssues === `false`) {
|
|
||||||
return ``;
|
return ``;
|
||||||
}
|
}
|
||||||
const ctx = github.context;
|
const ctx = github.context;
|
||||||
if (ctx.eventName !== `pull_request` && ctx.eventName !== `pull_request_target`) {
|
switch (ctx.eventName) {
|
||||||
|
case `pull_request`:
|
||||||
|
case `pull_request_target`:
|
||||||
|
return await fetchPullRequestPatch(ctx);
|
||||||
|
case `push`:
|
||||||
|
return await fetchPushPatch(ctx);
|
||||||
|
case `merge_group`:
|
||||||
|
core.info(JSON.stringify(ctx.payload));
|
||||||
|
return ``;
|
||||||
|
default:
|
||||||
core.info(`Not fetching patch for showing only new issues because it's not a pull request context: event name is ${ctx.eventName}`);
|
core.info(`Not fetching patch for showing only new issues because it's not a pull request context: event name is ${ctx.eventName}`);
|
||||||
return ``;
|
return ``;
|
||||||
}
|
}
|
||||||
const pull = ctx.payload.pull_request;
|
}
|
||||||
if (!pull) {
|
async function fetchPullRequestPatch(ctx) {
|
||||||
|
const pr = ctx.payload.pull_request;
|
||||||
|
if (!pr) {
|
||||||
core.warning(`No pull request in context`);
|
core.warning(`No pull request in context`);
|
||||||
return ``;
|
return ``;
|
||||||
}
|
}
|
||||||
@ -89175,7 +89189,7 @@ async function fetchPatch() {
|
|||||||
const patchResp = await octokit.rest.pulls.get({
|
const patchResp = await octokit.rest.pulls.get({
|
||||||
owner: ctx.repo.owner,
|
owner: ctx.repo.owner,
|
||||||
repo: ctx.repo.repo,
|
repo: ctx.repo.repo,
|
||||||
[`pull_number`]: pull.number,
|
[`pull_number`]: pr.number,
|
||||||
mediaType: {
|
mediaType: {
|
||||||
format: `diff`,
|
format: `diff`,
|
||||||
},
|
},
|
||||||
@ -89203,14 +89217,48 @@ async function fetchPatch() {
|
|||||||
return ``; // don't fail the action, but analyze without patch
|
return ``; // don't fail the action, but analyze without patch
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
async function fetchPushPatch(ctx) {
|
||||||
|
const octokit = github.getOctokit(core.getInput(`github-token`, { required: true }));
|
||||||
|
let patch;
|
||||||
|
try {
|
||||||
|
const patchResp = await octokit.rest.repos.compareCommits({
|
||||||
|
owner: ctx.repo.owner,
|
||||||
|
repo: ctx.repo.repo,
|
||||||
|
base: ctx.payload.before,
|
||||||
|
head: ctx.payload.after,
|
||||||
|
mediaType: {
|
||||||
|
format: `diff`,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
if (patchResp.status !== 200) {
|
||||||
|
core.warning(`failed to fetch push patch: response status is ${patchResp.status}`);
|
||||||
|
return ``; // don't fail the action, but analyze without patch
|
||||||
|
}
|
||||||
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
||||||
|
patch = patchResp.data;
|
||||||
|
}
|
||||||
|
catch (err) {
|
||||||
|
console.warn(`failed to fetch push patch:`, err);
|
||||||
|
return ``; // don't fail the action, but analyze without patch
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
const tempDir = await createTempDir();
|
||||||
|
const patchPath = path.join(tempDir, "push.patch");
|
||||||
|
core.info(`Writing patch to ${patchPath}`);
|
||||||
|
await writeFile(patchPath, (0, diffUtils_1.alterDiffPatch)(patch));
|
||||||
|
return patchPath;
|
||||||
|
}
|
||||||
|
catch (err) {
|
||||||
|
console.warn(`failed to save pull request patch:`, err);
|
||||||
|
return ``; // don't fail the action, but analyze without patch
|
||||||
|
}
|
||||||
|
}
|
||||||
async function prepareEnv() {
|
async function prepareEnv() {
|
||||||
const startedAt = Date.now();
|
const startedAt = Date.now();
|
||||||
// Prepare cache, lint and go in parallel.
|
// Prepare cache, lint and go in parallel.
|
||||||
await (0, cache_1.restoreCache)();
|
await (0, cache_1.restoreCache)();
|
||||||
const prepareLintPromise = prepareLint();
|
const lintPath = await prepareLint();
|
||||||
const patchPromise = fetchPatch();
|
const patchPath = await fetchPatch();
|
||||||
const lintPath = await prepareLintPromise;
|
|
||||||
const patchPath = await patchPromise;
|
|
||||||
core.info(`Prepared env in ${Date.now() - startedAt}ms`);
|
core.info(`Prepared env in ${Date.now() - startedAt}ms`);
|
||||||
return { lintPath, patchPath };
|
return { lintPath, patchPath };
|
||||||
}
|
}
|
||||||
@ -89248,15 +89296,33 @@ async function runLint(lintPath, patchPath) {
|
|||||||
.join(",");
|
.join(",");
|
||||||
addedArgs.push(`--out-format=${formats}`);
|
addedArgs.push(`--out-format=${formats}`);
|
||||||
userArgs = userArgs.replace(/--out-format=\S*/gi, "").trim();
|
userArgs = userArgs.replace(/--out-format=\S*/gi, "").trim();
|
||||||
if (patchPath) {
|
if (isOnlyNewIssues()) {
|
||||||
if (userArgNames.has(`new`) || userArgNames.has(`new-from-rev`) || userArgNames.has(`new-from-patch`)) {
|
if (userArgNames.has(`new`) || userArgNames.has(`new-from-rev`) || userArgNames.has(`new-from-patch`)) {
|
||||||
throw new Error(`please, don't specify manually --new* args when requesting only new issues`);
|
throw new Error(`please, don't specify manually --new* args when requesting only new issues`);
|
||||||
}
|
}
|
||||||
|
const ctx = github.context;
|
||||||
|
core.info(`only new issues on ${ctx.eventName}: ${patchPath}`);
|
||||||
|
switch (ctx.eventName) {
|
||||||
|
case `pull_request`:
|
||||||
|
case `pull_request_target`:
|
||||||
|
case `push`:
|
||||||
|
if (patchPath) {
|
||||||
addedArgs.push(`--new-from-patch=${patchPath}`);
|
addedArgs.push(`--new-from-patch=${patchPath}`);
|
||||||
// Override config values.
|
// Override config values.
|
||||||
addedArgs.push(`--new=false`);
|
addedArgs.push(`--new=false`);
|
||||||
addedArgs.push(`--new-from-rev=`);
|
addedArgs.push(`--new-from-rev=`);
|
||||||
}
|
}
|
||||||
|
break;
|
||||||
|
case `merge_group`:
|
||||||
|
addedArgs.push(`--new-from-rev=${ctx.payload.merge_group.base_sha}`);
|
||||||
|
// Override config values.
|
||||||
|
addedArgs.push(`--new=false`);
|
||||||
|
addedArgs.push(`--new-from-patch=`);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
const workingDirectory = core.getInput(`working-directory`);
|
const workingDirectory = core.getInput(`working-directory`);
|
||||||
const cmdArgs = {};
|
const cmdArgs = {};
|
||||||
if (workingDirectory) {
|
if (workingDirectory) {
|
||||||
|
94
dist/run/index.js
generated
vendored
94
dist/run/index.js
generated
vendored
@ -89146,26 +89146,40 @@ const version_1 = __nccwpck_require__(1946);
|
|||||||
const execShellCommand = (0, util_1.promisify)(child_process_1.exec);
|
const execShellCommand = (0, util_1.promisify)(child_process_1.exec);
|
||||||
const writeFile = (0, util_1.promisify)(fs.writeFile);
|
const writeFile = (0, util_1.promisify)(fs.writeFile);
|
||||||
const createTempDir = (0, util_1.promisify)(tmp_1.dir);
|
const createTempDir = (0, util_1.promisify)(tmp_1.dir);
|
||||||
|
function isOnlyNewIssues() {
|
||||||
|
const onlyNewIssues = core.getInput(`only-new-issues`, { required: true }).trim();
|
||||||
|
if (onlyNewIssues !== `false` && onlyNewIssues !== `true`) {
|
||||||
|
throw new Error(`invalid value of "only-new-issues": "${onlyNewIssues}", expected "true" or "false"`);
|
||||||
|
}
|
||||||
|
return onlyNewIssues === `true`;
|
||||||
|
}
|
||||||
async function prepareLint() {
|
async function prepareLint() {
|
||||||
const mode = core.getInput("install-mode").toLowerCase();
|
const mode = core.getInput("install-mode").toLowerCase();
|
||||||
const versionConfig = await (0, version_1.findLintVersion)(mode);
|
const versionConfig = await (0, version_1.findLintVersion)(mode);
|
||||||
return await (0, install_1.installLint)(versionConfig, mode);
|
return await (0, install_1.installLint)(versionConfig, mode);
|
||||||
}
|
}
|
||||||
async function fetchPatch() {
|
async function fetchPatch() {
|
||||||
const onlyNewIssues = core.getInput(`only-new-issues`, { required: true }).trim();
|
if (!isOnlyNewIssues()) {
|
||||||
if (onlyNewIssues !== `false` && onlyNewIssues !== `true`) {
|
|
||||||
throw new Error(`invalid value of "only-new-issues": "${onlyNewIssues}", expected "true" or "false"`);
|
|
||||||
}
|
|
||||||
if (onlyNewIssues === `false`) {
|
|
||||||
return ``;
|
return ``;
|
||||||
}
|
}
|
||||||
const ctx = github.context;
|
const ctx = github.context;
|
||||||
if (ctx.eventName !== `pull_request` && ctx.eventName !== `pull_request_target`) {
|
switch (ctx.eventName) {
|
||||||
|
case `pull_request`:
|
||||||
|
case `pull_request_target`:
|
||||||
|
return await fetchPullRequestPatch(ctx);
|
||||||
|
case `push`:
|
||||||
|
return await fetchPushPatch(ctx);
|
||||||
|
case `merge_group`:
|
||||||
|
core.info(JSON.stringify(ctx.payload));
|
||||||
|
return ``;
|
||||||
|
default:
|
||||||
core.info(`Not fetching patch for showing only new issues because it's not a pull request context: event name is ${ctx.eventName}`);
|
core.info(`Not fetching patch for showing only new issues because it's not a pull request context: event name is ${ctx.eventName}`);
|
||||||
return ``;
|
return ``;
|
||||||
}
|
}
|
||||||
const pull = ctx.payload.pull_request;
|
}
|
||||||
if (!pull) {
|
async function fetchPullRequestPatch(ctx) {
|
||||||
|
const pr = ctx.payload.pull_request;
|
||||||
|
if (!pr) {
|
||||||
core.warning(`No pull request in context`);
|
core.warning(`No pull request in context`);
|
||||||
return ``;
|
return ``;
|
||||||
}
|
}
|
||||||
@ -89175,7 +89189,7 @@ async function fetchPatch() {
|
|||||||
const patchResp = await octokit.rest.pulls.get({
|
const patchResp = await octokit.rest.pulls.get({
|
||||||
owner: ctx.repo.owner,
|
owner: ctx.repo.owner,
|
||||||
repo: ctx.repo.repo,
|
repo: ctx.repo.repo,
|
||||||
[`pull_number`]: pull.number,
|
[`pull_number`]: pr.number,
|
||||||
mediaType: {
|
mediaType: {
|
||||||
format: `diff`,
|
format: `diff`,
|
||||||
},
|
},
|
||||||
@ -89203,14 +89217,48 @@ async function fetchPatch() {
|
|||||||
return ``; // don't fail the action, but analyze without patch
|
return ``; // don't fail the action, but analyze without patch
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
async function fetchPushPatch(ctx) {
|
||||||
|
const octokit = github.getOctokit(core.getInput(`github-token`, { required: true }));
|
||||||
|
let patch;
|
||||||
|
try {
|
||||||
|
const patchResp = await octokit.rest.repos.compareCommits({
|
||||||
|
owner: ctx.repo.owner,
|
||||||
|
repo: ctx.repo.repo,
|
||||||
|
base: ctx.payload.before,
|
||||||
|
head: ctx.payload.after,
|
||||||
|
mediaType: {
|
||||||
|
format: `diff`,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
if (patchResp.status !== 200) {
|
||||||
|
core.warning(`failed to fetch push patch: response status is ${patchResp.status}`);
|
||||||
|
return ``; // don't fail the action, but analyze without patch
|
||||||
|
}
|
||||||
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
||||||
|
patch = patchResp.data;
|
||||||
|
}
|
||||||
|
catch (err) {
|
||||||
|
console.warn(`failed to fetch push patch:`, err);
|
||||||
|
return ``; // don't fail the action, but analyze without patch
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
const tempDir = await createTempDir();
|
||||||
|
const patchPath = path.join(tempDir, "push.patch");
|
||||||
|
core.info(`Writing patch to ${patchPath}`);
|
||||||
|
await writeFile(patchPath, (0, diffUtils_1.alterDiffPatch)(patch));
|
||||||
|
return patchPath;
|
||||||
|
}
|
||||||
|
catch (err) {
|
||||||
|
console.warn(`failed to save pull request patch:`, err);
|
||||||
|
return ``; // don't fail the action, but analyze without patch
|
||||||
|
}
|
||||||
|
}
|
||||||
async function prepareEnv() {
|
async function prepareEnv() {
|
||||||
const startedAt = Date.now();
|
const startedAt = Date.now();
|
||||||
// Prepare cache, lint and go in parallel.
|
// Prepare cache, lint and go in parallel.
|
||||||
await (0, cache_1.restoreCache)();
|
await (0, cache_1.restoreCache)();
|
||||||
const prepareLintPromise = prepareLint();
|
const lintPath = await prepareLint();
|
||||||
const patchPromise = fetchPatch();
|
const patchPath = await fetchPatch();
|
||||||
const lintPath = await prepareLintPromise;
|
|
||||||
const patchPath = await patchPromise;
|
|
||||||
core.info(`Prepared env in ${Date.now() - startedAt}ms`);
|
core.info(`Prepared env in ${Date.now() - startedAt}ms`);
|
||||||
return { lintPath, patchPath };
|
return { lintPath, patchPath };
|
||||||
}
|
}
|
||||||
@ -89248,15 +89296,33 @@ async function runLint(lintPath, patchPath) {
|
|||||||
.join(",");
|
.join(",");
|
||||||
addedArgs.push(`--out-format=${formats}`);
|
addedArgs.push(`--out-format=${formats}`);
|
||||||
userArgs = userArgs.replace(/--out-format=\S*/gi, "").trim();
|
userArgs = userArgs.replace(/--out-format=\S*/gi, "").trim();
|
||||||
if (patchPath) {
|
if (isOnlyNewIssues()) {
|
||||||
if (userArgNames.has(`new`) || userArgNames.has(`new-from-rev`) || userArgNames.has(`new-from-patch`)) {
|
if (userArgNames.has(`new`) || userArgNames.has(`new-from-rev`) || userArgNames.has(`new-from-patch`)) {
|
||||||
throw new Error(`please, don't specify manually --new* args when requesting only new issues`);
|
throw new Error(`please, don't specify manually --new* args when requesting only new issues`);
|
||||||
}
|
}
|
||||||
|
const ctx = github.context;
|
||||||
|
core.info(`only new issues on ${ctx.eventName}: ${patchPath}`);
|
||||||
|
switch (ctx.eventName) {
|
||||||
|
case `pull_request`:
|
||||||
|
case `pull_request_target`:
|
||||||
|
case `push`:
|
||||||
|
if (patchPath) {
|
||||||
addedArgs.push(`--new-from-patch=${patchPath}`);
|
addedArgs.push(`--new-from-patch=${patchPath}`);
|
||||||
// Override config values.
|
// Override config values.
|
||||||
addedArgs.push(`--new=false`);
|
addedArgs.push(`--new=false`);
|
||||||
addedArgs.push(`--new-from-rev=`);
|
addedArgs.push(`--new-from-rev=`);
|
||||||
}
|
}
|
||||||
|
break;
|
||||||
|
case `merge_group`:
|
||||||
|
addedArgs.push(`--new-from-rev=${ctx.payload.merge_group.base_sha}`);
|
||||||
|
// Override config values.
|
||||||
|
addedArgs.push(`--new=false`);
|
||||||
|
addedArgs.push(`--new-from-patch=`);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
const workingDirectory = core.getInput(`working-directory`);
|
const workingDirectory = core.getInput(`working-directory`);
|
||||||
const cmdArgs = {};
|
const cmdArgs = {};
|
||||||
if (workingDirectory) {
|
if (workingDirectory) {
|
||||||
|
109
src/run.ts
109
src/run.ts
@ -1,5 +1,6 @@
|
|||||||
import * as core from "@actions/core"
|
import * as core from "@actions/core"
|
||||||
import * as github from "@actions/github"
|
import * as github from "@actions/github"
|
||||||
|
import { Context } from "@actions/github/lib/context"
|
||||||
import { exec, ExecOptions } from "child_process"
|
import { exec, ExecOptions } from "child_process"
|
||||||
import * as fs from "fs"
|
import * as fs from "fs"
|
||||||
import * as path from "path"
|
import * as path from "path"
|
||||||
@ -15,6 +16,16 @@ const execShellCommand = promisify(exec)
|
|||||||
const writeFile = promisify(fs.writeFile)
|
const writeFile = promisify(fs.writeFile)
|
||||||
const createTempDir = promisify(dir)
|
const createTempDir = promisify(dir)
|
||||||
|
|
||||||
|
function isOnlyNewIssues(): boolean {
|
||||||
|
const onlyNewIssues = core.getInput(`only-new-issues`, { required: true }).trim()
|
||||||
|
|
||||||
|
if (onlyNewIssues !== `false` && onlyNewIssues !== `true`) {
|
||||||
|
throw new Error(`invalid value of "only-new-issues": "${onlyNewIssues}", expected "true" or "false"`)
|
||||||
|
}
|
||||||
|
|
||||||
|
return onlyNewIssues === `true`
|
||||||
|
}
|
||||||
|
|
||||||
async function prepareLint(): Promise<string> {
|
async function prepareLint(): Promise<string> {
|
||||||
const mode = core.getInput("install-mode").toLowerCase()
|
const mode = core.getInput("install-mode").toLowerCase()
|
||||||
const versionConfig = await findLintVersion(<InstallMode>mode)
|
const versionConfig = await findLintVersion(<InstallMode>mode)
|
||||||
@ -23,31 +34,42 @@ async function prepareLint(): Promise<string> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
async function fetchPatch(): Promise<string> {
|
async function fetchPatch(): Promise<string> {
|
||||||
const onlyNewIssues = core.getInput(`only-new-issues`, { required: true }).trim()
|
if (!isOnlyNewIssues()) {
|
||||||
if (onlyNewIssues !== `false` && onlyNewIssues !== `true`) {
|
|
||||||
throw new Error(`invalid value of "only-new-issues": "${onlyNewIssues}", expected "true" or "false"`)
|
|
||||||
}
|
|
||||||
if (onlyNewIssues === `false`) {
|
|
||||||
return ``
|
return ``
|
||||||
}
|
}
|
||||||
|
|
||||||
const ctx = github.context
|
const ctx = github.context
|
||||||
if (ctx.eventName !== `pull_request` && ctx.eventName !== `pull_request_target`) {
|
|
||||||
|
switch (ctx.eventName) {
|
||||||
|
case `pull_request`:
|
||||||
|
case `pull_request_target`:
|
||||||
|
return await fetchPullRequestPatch(ctx)
|
||||||
|
case `push`:
|
||||||
|
return await fetchPushPatch(ctx)
|
||||||
|
case `merge_group`:
|
||||||
|
core.info(JSON.stringify(ctx.payload))
|
||||||
|
return ``
|
||||||
|
default:
|
||||||
core.info(`Not fetching patch for showing only new issues because it's not a pull request context: event name is ${ctx.eventName}`)
|
core.info(`Not fetching patch for showing only new issues because it's not a pull request context: event name is ${ctx.eventName}`)
|
||||||
return ``
|
return ``
|
||||||
}
|
}
|
||||||
const pull = ctx.payload.pull_request
|
}
|
||||||
if (!pull) {
|
|
||||||
|
async function fetchPullRequestPatch(ctx: Context): Promise<string> {
|
||||||
|
const pr = ctx.payload.pull_request
|
||||||
|
if (!pr) {
|
||||||
core.warning(`No pull request in context`)
|
core.warning(`No pull request in context`)
|
||||||
return ``
|
return ``
|
||||||
}
|
}
|
||||||
|
|
||||||
const octokit = github.getOctokit(core.getInput(`github-token`, { required: true }))
|
const octokit = github.getOctokit(core.getInput(`github-token`, { required: true }))
|
||||||
|
|
||||||
let patch: string
|
let patch: string
|
||||||
try {
|
try {
|
||||||
const patchResp = await octokit.rest.pulls.get({
|
const patchResp = await octokit.rest.pulls.get({
|
||||||
owner: ctx.repo.owner,
|
owner: ctx.repo.owner,
|
||||||
repo: ctx.repo.repo,
|
repo: ctx.repo.repo,
|
||||||
[`pull_number`]: pull.number,
|
[`pull_number`]: pr.number,
|
||||||
mediaType: {
|
mediaType: {
|
||||||
format: `diff`,
|
format: `diff`,
|
||||||
},
|
},
|
||||||
@ -77,6 +99,45 @@ async function fetchPatch(): Promise<string> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
async function fetchPushPatch(ctx: Context): Promise<string> {
|
||||||
|
const octokit = github.getOctokit(core.getInput(`github-token`, { required: true }))
|
||||||
|
|
||||||
|
let patch: string
|
||||||
|
try {
|
||||||
|
const patchResp = await octokit.rest.repos.compareCommits({
|
||||||
|
owner: ctx.repo.owner,
|
||||||
|
repo: ctx.repo.repo,
|
||||||
|
base: ctx.payload.before,
|
||||||
|
head: ctx.payload.after,
|
||||||
|
mediaType: {
|
||||||
|
format: `diff`,
|
||||||
|
},
|
||||||
|
})
|
||||||
|
|
||||||
|
if (patchResp.status !== 200) {
|
||||||
|
core.warning(`failed to fetch push patch: response status is ${patchResp.status}`)
|
||||||
|
return `` // don't fail the action, but analyze without patch
|
||||||
|
}
|
||||||
|
|
||||||
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
||||||
|
patch = patchResp.data as any
|
||||||
|
} catch (err) {
|
||||||
|
console.warn(`failed to fetch push patch:`, err)
|
||||||
|
return `` // don't fail the action, but analyze without patch
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
const tempDir = await createTempDir()
|
||||||
|
const patchPath = path.join(tempDir, "push.patch")
|
||||||
|
core.info(`Writing patch to ${patchPath}`)
|
||||||
|
await writeFile(patchPath, alterDiffPatch(patch))
|
||||||
|
return patchPath
|
||||||
|
} catch (err) {
|
||||||
|
console.warn(`failed to save pull request patch:`, err)
|
||||||
|
return `` // don't fail the action, but analyze without patch
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
type Env = {
|
type Env = {
|
||||||
lintPath: string
|
lintPath: string
|
||||||
patchPath: string
|
patchPath: string
|
||||||
@ -87,11 +148,9 @@ async function prepareEnv(): Promise<Env> {
|
|||||||
|
|
||||||
// Prepare cache, lint and go in parallel.
|
// Prepare cache, lint and go in parallel.
|
||||||
await restoreCache()
|
await restoreCache()
|
||||||
const prepareLintPromise = prepareLint()
|
|
||||||
const patchPromise = fetchPatch()
|
|
||||||
|
|
||||||
const lintPath = await prepareLintPromise
|
const lintPath = await prepareLint()
|
||||||
const patchPath = await patchPromise
|
const patchPath = await fetchPatch()
|
||||||
|
|
||||||
core.info(`Prepared env in ${Date.now() - startedAt}ms`)
|
core.info(`Prepared env in ${Date.now() - startedAt}ms`)
|
||||||
|
|
||||||
@ -144,16 +203,38 @@ async function runLint(lintPath: string, patchPath: string): Promise<void> {
|
|||||||
addedArgs.push(`--out-format=${formats}`)
|
addedArgs.push(`--out-format=${formats}`)
|
||||||
userArgs = userArgs.replace(/--out-format=\S*/gi, "").trim()
|
userArgs = userArgs.replace(/--out-format=\S*/gi, "").trim()
|
||||||
|
|
||||||
if (patchPath) {
|
if (isOnlyNewIssues()) {
|
||||||
if (userArgNames.has(`new`) || userArgNames.has(`new-from-rev`) || userArgNames.has(`new-from-patch`)) {
|
if (userArgNames.has(`new`) || userArgNames.has(`new-from-rev`) || userArgNames.has(`new-from-patch`)) {
|
||||||
throw new Error(`please, don't specify manually --new* args when requesting only new issues`)
|
throw new Error(`please, don't specify manually --new* args when requesting only new issues`)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const ctx = github.context
|
||||||
|
|
||||||
|
core.info(`only new issues on ${ctx.eventName}: ${patchPath}`)
|
||||||
|
|
||||||
|
switch (ctx.eventName) {
|
||||||
|
case `pull_request`:
|
||||||
|
case `pull_request_target`:
|
||||||
|
case `push`:
|
||||||
|
if (patchPath) {
|
||||||
addedArgs.push(`--new-from-patch=${patchPath}`)
|
addedArgs.push(`--new-from-patch=${patchPath}`)
|
||||||
|
|
||||||
// Override config values.
|
// Override config values.
|
||||||
addedArgs.push(`--new=false`)
|
addedArgs.push(`--new=false`)
|
||||||
addedArgs.push(`--new-from-rev=`)
|
addedArgs.push(`--new-from-rev=`)
|
||||||
}
|
}
|
||||||
|
break
|
||||||
|
case `merge_group`:
|
||||||
|
addedArgs.push(`--new-from-rev=${ctx.payload.merge_group.base_sha}`)
|
||||||
|
|
||||||
|
// Override config values.
|
||||||
|
addedArgs.push(`--new=false`)
|
||||||
|
addedArgs.push(`--new-from-patch=`)
|
||||||
|
break
|
||||||
|
default:
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
const workingDirectory = core.getInput(`working-directory`)
|
const workingDirectory = core.getInput(`working-directory`)
|
||||||
const cmdArgs: ExecOptions = {}
|
const cmdArgs: ExecOptions = {}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user