w-puppeteer-uitest
Version:
A uitest package for web developer.
174 lines (129 loc) • 5.93 kB
HTML
<html lang="en">
<head>
<meta charset="utf-8">
<title>expTest.mjs - Documentation</title>
<script src="scripts/prettify/prettify.js"></script>
<script src="scripts/prettify/lang-css.js"></script>
<!--[if lt IE 9]>
<script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
<![endif]-->
<link type="text/css" rel="stylesheet" href="styles/prettify.css">
<link type="text/css" rel="stylesheet" href="styles/jsdoc.css">
<script src="scripts/nav.js" defer></script>
<meta name="viewport" content="width=device-width, initial-scale=1.0">
</head>
<body>
<input type="checkbox" id="nav-trigger" class="nav-trigger" />
<label for="nav-trigger" class="navicon-button x">
<div class="navicon"></div>
</label>
<label for="nav-trigger" class="overlay"></label>
<nav >
<h2><a href="index.html">Home</a></h2><h3>Classes</h3><ul><li><a href="w-puppeteer-uitest.html">w-puppeteer-uitest</a><ul class='methods'><li data-type='method'><a href="w-puppeteer-uitest.html#.build">build</a></li><li data-type='method'><a href="w-puppeteer-uitest.html#.compareB64">compareB64</a></li><li data-type='method'><a href="w-puppeteer-uitest.html#.expBuild">expBuild</a></li><li data-type='method'><a href="w-puppeteer-uitest.html#.expTest">expTest</a></li><li data-type='method'><a href="w-puppeteer-uitest.html#.getB64">getB64</a></li><li data-type='method'><a href="w-puppeteer-uitest.html#.getFiles">getFiles</a></li><li data-type='method'><a href="w-puppeteer-uitest.html#.readJson">readJson</a></li><li data-type='method'><a href="w-puppeteer-uitest.html#.test">test</a></li></ul></li></ul>
</nav>
<div id="main">
<h1 class="page-title">expTest.mjs</h1>
<section>
<article>
<pre class="prettyprint source linenums"><code>import fs from 'fs'
import get from 'lodash-es/get.js'
import ispint from 'wsemi/src/ispint.mjs'
import isnum from 'wsemi/src/isnum.mjs'
import cint from 'wsemi/src/cint.mjs'
import cdbl from 'wsemi/src/cdbl.mjs'
import pmMap from 'wsemi/src/pmMap.mjs'
import getB64 from './getB64.mjs'
import compareB64 from './compareB64.mjs'
/**
* 測試範例之快照(screenshot)是否與正確版相同
*
* @memberOf w-puppeteer-uitest
* @param {Array} items 輸入html範例所在之資料夾字串
* @param {String} item.name 輸入item名稱字串
* @param {String} item.url 輸入item所需瀏覽範例位置字串
* @param {Array} item.actions 輸入item所需執行自動化操作動作陣列
* @param {String} item.fn_base64 輸入item儲存圖base64資料之路徑字串
* @param {Object} [optExp={}] 輸入設定物件,預設為{}
* @param {Boolean} [optExp.headless=true] 輸入是否以無頭方式開啟網頁,預設為true
* @param {Object} [optExp.viewport={ width: 800, height: 600 }] 輸入網頁開啟後之viewport,預設為{ width: 800, height: 600 }
* @param {Number} [optExp.num_web=10] 輸入平行啟動瀏覽器之數量,預設為10
* @param {Number} [optExp.ratio_similar=1] 輸入偵測圖片相近度,預設為1,也就是完全相似
* @returns {Promise} 回傳Promise,resolve為建置成功,reject為建置失敗item名稱
*/
async function expTest(items, optExp = {}) {
//headless, viewport, waitsec, num_web, ratio_similar
let headless = get(optExp, 'headless')
let viewport = get(optExp, 'viewport')
let waitsec = get(optExp, 'waitsec')
let num_web = 10
if (ispint(optExp.num_web)) {
num_web = cint(optExp.num_web)
}
let ratio_similar = 1
if (isnum(optExp.ratio_similar)) {
ratio_similar = cdbl(optExp.ratio_similar)
}
//pmMap, 平行化處理
let bstop = false //若使用map平行化時, 多執行序啟動瀏覽器有錯誤會先reject, 但其他已啟動的瀏覽器一樣仍於閉包內會完成該任務, 故會呼叫所屬console.log, 通過bstop來停止這種情況之輸出
return pmMap(items, async function (v) {
console.log('expTest: ' + v.name)
//opt
let opt = {
headless,
viewport,
actions: v.actions,
waitsec,
}
//getB64
let b64_now = await getB64(v.url, opt)
//b64_expected
let b64_expected = fs.readFileSync(v.fn_base64, 'utf8')
//b
let b
if (ratio_similar === 1) {
b = b64_now === b64_expected
}
else {
let r = await compareB64(b64_now, b64_expected)
b = r >= ratio_similar
let s = b ? ' >= ' : '<'
console.log(`ratio[${r}] ${s} ratio_similar[${ratio_similar}]`)
}
//check
if (b) {
if (!bstop) {
console.log('success: ' + v.name)
}
}
else {
if (!bstop) {
console.log('error: ' + v.name)
fs.writeFileSync(v.name + '.err.png', b64_now, 'base64')
}
bstop = true
return Promise.reject(v.name)
}
return v.name
}, num_web)
.then(() => {
console.log('\x1b[32m%s\x1b[0m', 'expTest success')
})
.catch((msg) => {
console.log('\x1b[31m%s\x1b[0m', 'expTest error: ' + msg)
})
}
export default expTest
</code></pre>
</article>
</section>
</div>
<br class="clear">
<footer>
Documentation generated by <a href="https://github.com/jsdoc3/jsdoc">JSDoc 4.0.2</a> on Sat Mar 23 2024 23:37:02 GMT+0800 (台北標準時間) using the <a href="https://github.com/clenemt/docdash">docdash</a> theme.
</footer>
<script>prettyPrint();</script>
<script src="scripts/polyfill.js"></script>
<script src="scripts/linenumber.js"></script>
</body>
</html>