-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathmain.ts
80 lines (68 loc) · 3.22 KB
/
main.ts
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
import * as core from "@actions/core";
import { parseInputs } from "./config";
import { GitHubApiClient } from "./github-api-client";
import { GraphBuilder } from "./graph-builder";
import { IssueContentParser } from "./issue-content-parser";
import { MermaidNode } from "./mermaid-node";
import { MermaidRender } from "./mermaid-render";
const run = async (): Promise<void> => {
try {
const inputs = parseInputs();
const githubApiClient = new GitHubApiClient(inputs.githubToken);
const issueContentParser = new IssueContentParser();
const mermaidRender = new MermaidRender(inputs.includeLegend);
const rootIssue = await githubApiClient.getIssue(inputs.rootIssue);
if (issueContentParser.isIssueClosed(rootIssue)) {
core.info("Skipping generation of mermaid diagram because issue is closed");
return;
}
const rootIssueTasklist = issueContentParser.extractIssueTasklist(rootIssue);
core.info(`Found ${rootIssueTasklist.length} work items in task list.`);
if (rootIssueTasklist.length === 0) {
core.info("Skipping generation of mermaid diagram because there is no issues in tasklist");
return;
}
core.info("Building dependency graph...");
const graphBuilder = new GraphBuilder(inputs.includeFinishNode);
for (const issueRef of rootIssueTasklist) {
const issue = await githubApiClient.getIssue(issueRef);
const issueDetails = MermaidNode.createFromGitHubIssue(issue);
const issueDependencies = issueContentParser.extractIssueDependencies(issue, issueRef);
graphBuilder.addIssue(issueRef, issueDetails);
issueDependencies.forEach(x => graphBuilder.addDependency(x, issueRef));
}
const graph = graphBuilder.getGraph();
const renderedContent = mermaidRender.render(graph);
core.info("Rendering dependency graph into mermaid...");
core.setOutput("mermaid-diagram", renderedContent);
core.startGroup("Mermaid diagram");
core.info(renderedContent);
core.endGroup();
core.info("Preparing updated root issue content...");
const updatedIssueContent = issueContentParser.replaceIssueContent(
rootIssue,
inputs.sectionTitle,
renderedContent
);
core.startGroup("Updated root issue content");
core.info(updatedIssueContent);
core.endGroup();
if (issueContentParser.isIssueContentIdentical(rootIssue, updatedIssueContent)) {
core.info(
"Skipping update of root issue content because new content is identical to current content. No changes in mermaid in diagram."
);
return;
}
if (inputs.dryRun) {
console.log("Action is run in dry-run mode. Root issue won't be updated");
return;
}
core.info("Updating root issue content...");
await githubApiClient.updateIssueContent(inputs.rootIssue, updatedIssueContent);
core.info("Root issue is updated.");
} catch (error: unknown) {
core.setFailed(error instanceof Error ? error.message : (error as string));
throw error;
}
};
run();