-
Notifications
You must be signed in to change notification settings - Fork 40
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
5 changed files
with
120 additions
and
102 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,30 @@ | ||
import showdown from 'showdown'; | ||
|
||
import { Reporter } from '.'; | ||
import markdownReporter from './markdown'; | ||
|
||
const htmlReporter: Reporter<string> = async (jobResults, browser) => { | ||
const markdownReport = await markdownReporter(jobResults, browser); | ||
const showdownConverter = new showdown.Converter({tables: true}); | ||
return ` | ||
<!DOCTYPE html> | ||
<html> | ||
<head> | ||
<meta charset="UTF-8"> | ||
<link | ||
href="https://unpkg.com/primer/build/build.css" | ||
rel="stylesheet"> | ||
<style> | ||
body { | ||
display: inline-block; | ||
} | ||
</style> | ||
</head> | ||
<body class="markdown-body"> | ||
${showdownConverter.makeHtml(markdownReport)} | ||
</body> | ||
</html> | ||
`; | ||
} | ||
|
||
export default htmlReporter; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,26 @@ | ||
import { Reporter } from '.'; | ||
import htmlReporter from './html'; | ||
|
||
const imageReporter: Reporter<void> = async (jobResults, browser) => { | ||
const htmlReport = await htmlReporter(jobResults, browser); | ||
const page = await browser.newPage(); | ||
await page.setContent(htmlReport); | ||
const rect = await page.evaluate(() => { | ||
const element = document.querySelector('.markdown-body'); | ||
if (!element) | ||
throw new Error("Markdown body is not found!") | ||
const {left, top, width, height} = element.getBoundingClientRect(); | ||
return {left, top, width, height, id: element.id}; | ||
}); | ||
await page.screenshot({ | ||
path: './tmp/health-check.png', | ||
clip: { | ||
x: rect.left, | ||
y: rect.top, | ||
width: rect.width, | ||
height: rect.height, | ||
} | ||
}); | ||
} | ||
|
||
export default imageReporter; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
import puppeteer from 'puppeteer'; | ||
|
||
import { JobResult } from '..'; | ||
|
||
export type Reporter<T extends (Buffer | string | void)> = | ||
(jobResults: JobResult[], browser: puppeteer.Browser) => (Promise<T> | T); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,54 @@ | ||
import { Reporter } from '.'; | ||
|
||
const markdownReporter: Reporter<string> = jobResults => { | ||
let report = '| 사이트 | 상태 |\n|------|-------|'; | ||
for (const jobResult of jobResults) { | ||
let message; | ||
if (jobResult.type == 'error') { | ||
message = '• ❓테스트 실패'; | ||
} else { | ||
message = '• ' | ||
if (jobResult.problems && jobResult.problems.length == 0) { | ||
message += `✅`; | ||
} else { | ||
message += `❌`; | ||
} | ||
const links = [`[url](${jobResult.url})`]; | ||
for(const issueNumber of jobResult.related) { | ||
links.push(`[${issueNumber}](https://github.com/disjukr/just-news/issues/${issueNumber})`); | ||
} | ||
message += '(' + links.join(', ') + ')'; | ||
|
||
const problemMessages = []; | ||
for (const [problem, reason] of jobResult.problems) { | ||
switch (reason) { | ||
case 'missing': | ||
problemMessages.push(`\`잘못된 ${sayProblem(problem)}\``); | ||
break; | ||
case 'invalid': | ||
problemMessages.push(`\`${sayProblem(problem)} 누락됨\``); | ||
break; | ||
} | ||
} | ||
message += problemMessages.join(', '); | ||
|
||
} | ||
report += `\n| ${jobResult.impl} | ${message} |`; | ||
} | ||
return report; | ||
}; | ||
|
||
export default markdownReporter; | ||
|
||
const sayProblem = (text: string) => { | ||
switch (text) { | ||
case 'title': return '제목'; | ||
case 'subtitle': return '부제목'; | ||
case 'content': return '본문'; | ||
case 'timestamp.created': return '작성일'; | ||
case 'timestamp.lastModified': return '수정일'; | ||
case 'reporters.0.name': return '작성자 이름'; | ||
case 'reporters.0.mail': return '작성자 이메일'; | ||
} | ||
return text; | ||
}; |