- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如果我在 pm2 下使用 TestCafe 运行我的应用程序,如果 Testcafe 脚本使用 FS 操作,pm2 总是会崩溃。
async function unlinkFiles () {
if(fs.existsSync(downloadsFolder()+'/export.xml')){
fs.unlinkSync(downloadsFolder()+'/export.xml');
}
if(fs.existsSync(downloadsFolder()+'/export.json')){
fs.unlinkSync(downloadsFolder()+'/export.json');
}
return true;
}
如果我注释掉这个 fs 操作,pm2 将不会在这个位置崩溃,但稍后会崩溃。所以每次在pm2下的TestCafe的脚本中使用FS操作,pm2都会崩溃。这是已知问题吗?
我的脚本:
import { Selector, ClientFunction } from 'testcafe';
import fs from "fs";
import downloadsFolder from "downloads-folder";
import xpath from 'xpath';
import jp from 'jsonpath';
import {DOMParser} from 'xmldom';
fixture `SMTest 1-11-2019 (23:31:12)`
const getStyleWidthInPercents = ClientFunction(() => {
var calVar = Math.min(100, parseInt(document.querySelector('.progress-bar.progress-bar-success').style.width)) + '%';
return calVar;
});
const compareValues = ClientFunction(test1 => {
const enumVar = document.querySelector(test1).innerHTML;
return enumVar;
});
test
.httpAuth({
username: 'xxx',
password: 'xxx'
})
('RV_mvK22', async t => {
console.log('tcafeprogress:0');
await t
.navigateTo("xxx")
.resizeWindow(1280, 720)
async function unlinkFiles () {
if(fs.existsSync(downloadsFolder()+'/export.xml')){
fs.unlinkSync(downloadsFolder()+'/export.xml');
}
if(fs.existsSync(downloadsFolder()+'/export.json')){
fs.unlinkSync(downloadsFolder()+'/export.json');
}
return true;
}
console.log('tcafeprogress:5');
await t
.expect(await unlinkFiles()).ok()
await t
.wait(2000)
.click(Selector('a').withText('Regelwerk'))
//.typeText(Selector('#settingsTable_filter').find('.form-control.input-sm'), 'tcafe')
//.wait(2000)
.click(Selector('button').withText('Upload'))
console.log('tcafeprogress:10');
await t
.setFilesToUpload(Selector('#fileupload'), ['./uploads/RV_mvk2.xml'])
.wait(2000)
//Cheap Developed UI with Workaround here
await t
.expect(getStyleWidthInPercents()).eql('100%', {timeout: 90000})
console.log('tcafeprogress:20');
await t
.wait(2000)
.click(Selector('.btn.btn-secondary.close-button[data-dismiss="modal"]'))
.wait(2000)
//Upload success, now search and create XML
.typeText(Selector('#settingsTable_filter').find('.form-control.input-sm'), 'RV_mvk2.xml')
.wait(2000)
//.debug()
.click(Selector('button').withText('Erstellen'))
console.log('tcafeprogress:30');
//Prüfen ob das Fenster zu geht, wenn nicht dann abbrechen.
//Vielleicht die ID Exists?
await t
.expect(Selector('#ContainerId').exists).ok('War wohl nicht erfolgreich',{ timeout: 300000 })
const korpusid = await Selector('#ContainerId').innerText;
console.log('tcafeprogress:40');
//If fail, please note that the report will always report one step more.
const value0 = await Selector('#KH').value
await t
.expect(compareValues('#KH_value')).eql(value0,'Wertvergleich fehlgeschlagen', {timeout: 40000})
const value1 = await Selector('#KB').value
await t
.expect(compareValues('#KB_value')).eql(value1,'Wertvergleich fehlgeschlagen', {timeout: 40000})
const value2 = await Selector('#KT').value
await t
.expect(compareValues('#KT_value')).eql(value2,'Wertvergleich fehlgeschlagen', {timeout: 40000})
const value3 = await Selector('#Plattendicke').value
await t
.expect(compareValues('#Plattendicke_value')).eql(value3,'Wertvergleich fehlgeschlagen', {timeout: 40000})
const value4 = await Selector('#Schiene_Size_x').value
await t
.expect(compareValues('#Size_x_value')).eql(value4,'Wertvergleich fehlgeschlagen', {timeout: 40000})
.wait(2000)
console.log('tcafeprogress:50');
//XML DOWNLOAD
await t
.click(Selector('button').withText('Aktionen'))
.click(Selector('a').withText('Xml Exportieren'));
await t
.wait(6000)
await t .expect(fs.existsSync(downloadsFolder()+'/export.xml')).ok()
//JSON DOWNLOAD
await t
.click(Selector('button').withText('Aktionen'))
.click(Selector('a').withText('Preis Exportieren'))
await t
.wait(6000)
await t.expect(fs.existsSync(downloadsFolder()+'/export.json')).ok()
console.log('tcafeprogress:70');
//Nun müssten das XML öffnen und XPATH lesen.
async function getXMLInfo (path,attr) {
var xml = fs.readFileSync(downloadsFolder()+'/export.xml', 'utf8').toString();
var doc = new DOMParser().parseFromString(xml);
var enumeration = '';
if(attr===true){
enumeration = xpath.select1(path, doc).value;
}else{
enumeration = xpath.select(path, doc);
}
var noXML = enumeration.toString();
noXML = noXML.replace(/\n| | /g, ' ');
noXML = noXML.replace(/ {1,}/g,' ');
console.log(noXML);
return noXML;
}
await t
.expect(await getXMLInfo('//CCSYSTEMCABINETID[1]/text()[1]',false)).eql(korpusid,'XML Wertvergleich fehlgeschlagen', {timeout: 40000})
await t
.expect(await getXMLInfo('//CabinetPart[@id=\'ID0001\'][1]/@name',true)).eql('Unterboden','XML Wertvergleich fehlgeschlagen', {timeout: 40000})
await t
.expect(await getXMLInfo('//ExternalPart[1]/@identifier',true)).eql('schiene_xyz','XML Wertvergleich fehlgeschlagen', {timeout: 40000})
await t
.expect(await getXMLInfo('//ExternalPart[1]/@length',true)).eql('1000','XML Wertvergleich fehlgeschlagen', {timeout: 40000})
await t
.expect(await getXMLInfo('//point[4]/@coordinate',true)).eql('1200 23 0','XML Wertvergleich fehlgeschlagen', {timeout: 40000})
console.log('tcafeprogress:80');
async function getJSONInfo (path) {
var xml = fs.readFileSync(downloadsFolder()+'/export.json', 'utf8').toString();
if(path==='$..*'){
console.log("Alles");
return xml;
}
var enumeration = jp.query(JSON.parse(xml), path);
console.log(enumeration.toString());
return enumeration.toString();
}
await t
.expect(await getJSONInfo('$..CumulatedList[1].Name')).eql('schiene_xyz','JSON Wertvergleich fehlgeschlagen', {timeout: 40000})
console.log('tcafeprogress:100');
});
PM2 随报告崩溃。我不知道为什么显示 JSON 错误,因为这一步没有 JSON 函数。通过使用 try and error 调试代码,我能够将问题减少到节点 fs 操作。
最佳答案
对于所有有类似问题的人。在我的例子中,问题是节点模块“下载文件夹”中的子进程 exec。删除 Exec 语句后,崩溃消失了。
关于testing - PM2 Testcafe fs 运行导致崩溃,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58690238/
在将网站从 GoDaddy 共享服务器传输到 EC2 实例的过程中。处理流量,在典型的一天的高峰时段,大约有 300 名活跃访客,至少可以说是有问题的。我的 CPU 使用率缓慢上升,最终达到 100%
我在一个 PM 系统上工作,我希望在最后收到的 PM 上方列出一次对话的先前发送的 PM。但我的问题是:如何在数据库中设置这样的表?我玩了一会儿关于为每个特定对话使用一个 ID,但是该 ID 的来源是
我想从给定的文本字符串中计算小时数和分钟数,目前我使用一些 excel 内置函数创建了以下公式, 示例文本字符串: 7.00pm to 8.00pm or 9.00am to 11.45pm or 1
我有一个字符串,其中包含:14 Dec 2011 9:45 am(注意“AM”没有大写) 现在我想用它创建一个 datetime 变量。 我试着查看 this ,但这与我想要的相反。我也试过this
之前创建的测试使用 DateTimeFormatter.ofPattern("ha"); 并返回 "10AM"(对于 '2017-04-09T10:00-06 :00[美国/山区]'). 在我的 Ma
我编写了正则表达式来捕获 HH:MM AM/PM/am/pm 但它无法提取精确的模式 正则表达式代码: import re def replace_entities(example): res
我的 Sql 查询如下所示: SELECT monday FROM `restaurantslive` 结果是 我想做的是在分钟后附加“AM”和“PM”,例如其中一条记录是 6:30–10:30A
我正在使用 codeigniter 和 jquery datetimepicker 插件。在我的 View 页面上,我有类似 的日期时间选择器格式 $(".traveler").datetimepic
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: Android date/time displaying 0 instead of 12 下面是我使用的代码
我正在构建类似考试日期表的内容。我目前在查找时间之间的冲突时遇到问题.. 我有一个存储时间间隔的字符串列表,例如- List times = new List(); times.Add("6:00 P
DateTimeFormatter's API reference似乎错过了正确格式化 am-pm-of-day 的细节,我总是可以使用 String.replace() 但我觉得将选项更改为 AM
我在转换来自服务器的时间时遇到问题,我想将其转换为 24 小时制。我正在使用以下代码: String timeComeFromServer = "3:30 PM"; SimpleDateFormat
从 pm 帮助,我得到这个: pm uninstall: removes a package from the system. Options: -k: keep the data and c
我在前端输入日期为 10:00 AM 、12:00 PM 等...(表示 12 小时格式)。现在我想将该值保存在数据库中的 time 数据类型列中。我如何将该 AM PM 值保存到 MySQL 中的
我在执行使用 Elasticsearch.pm(新版本,小写)模块的 perl 脚本时遇到问题。 该脚本是正确的(我还使用 perl -c 选项检查了语法),但是当我尝试执行它时,我收到了这个错误:
在这个JDO中,为什么这里需要.class? Query averageSalaryQuery = pm.newQuery(Employee.class); 如果可能,我更愿意编写这种更简洁的语法?
我正在使用 2 个字段,这些字段存储为 smallint 军事结构化时间。编辑我在 IBM Informix Dynamic Server 版本 10.00.FC9 上运行 beg_tm 和 end_
我刚刚查看了 http://www.cronmaker.com/并尝试为以下场景创建 cron 表达式。 在周一和周二的两个特定时间(即 1:24 和 3:34)运行作业。 我是为此生成以下表达式的。
我想将字符串:24/11/2016 04:30 pm 转换为日期时间值:11/24/2016 04:30 pm。 我的代码为: DateTime date = DateTime.ParseExact(
这不是更困惑吗?难道不应该反过来这样更容易记住吗? 最佳答案 查看此备忘单:http://cheat.errtheblog.com/s/strftime/ Ruby 1.8 之前好像没有%P 选项,所
我是一名优秀的程序员,十分优秀!