javascript - 如何使用 npm test 测试我的计算器?
问题描述
我有一个简单的计算器网络项目:https ://github.com/DANIILNEDOSTUP/js-calculator
我想使用npm + jest做简单的测试(例如加法和减法) 。我创建了package.json并写了这些行:
{
"scripts": {
"test": "jest"
}
}
然后创建script.test.js文件并写了几行:
const add = require('./script');
test('adds 1 + 2 to equal 3', () => {
expect(add(1, 2)).toBe(3);
});
然后我从终端调用npm test命令(我使用 Ubuntu 20.04)
然后我看到一个错误:
TypeError: Cannot read property 'addEventListener' of null
并抱怨 131 行代码
clearKey.addEventLisener('click', clearEquation);
进行测试是否现实?
我想为这个应用程序制作 CI/CD,我不太懂 JavaScript。
解决方案
我可以看到的主要问题是您的代码甚至没有导出任何内容。您将所有内容都放在一个文件script.js
中,这不是一个好习惯,可测试的代码会很烦人;不过,暂时还可以。要解决您的问题,您的脚本应导出该add
方法。
像这样的东西应该工作。
在最后scripts.js
写这样的东西
module.exports = { add }
然后在你的测试中
const { add } = require('./script');
test('adds 1 + 2 to equal 3', () => {
expect(add(1, 2)).toBe(3);
});
编辑
如评论中所述,这在网络浏览器中不起作用。
但是,我能想到的一种技巧是检查 module.exports 是否存在。所以添加到scripts.js
以下代码应该“修复它”
if (typeof module.exports !== 'undefined') {
module.exports = { add }
}
我可以考虑的另一个解决方案是将所有测试代码移到scripts.js
这也不是一个好主意(实际上这是一个非常糟糕的主意)并且它不会解决您的特定问题,因为您需要 dom 支持。
编辑 2
如评论中所述,DOMS 不受支持,node.js
事实上您正在调用一个测试脚本,该脚本需要一个尝试运行整个文件的模块,该模块在到达 DOM 部分时会失败,以便更好地解决您的问题真的需要将你的代码分解成模块。
此外,我们可以并且将在我们的案例中使用 webpack。如果不使用 webpack,这几乎是不可能的(至少对我而言)。另外,我强烈建议您学习webpack
,因为这对您尝试做的事情非常重要。
事不宜迟,这是您的文件夹结构
- | dist(此文件夹由 webpack 自动生成)
- | 源代码
- | 算术.js
- | 脚本.js
- | 索引.html
- | 样式.css
- | 包.json
- | webpack.config.js
- | 测试.js
以及你拥有的所有其他东西,显然它可以被分解得更多并创建更好的代码,但我试图在这里保持简单,而不是让你的逻辑过于复杂。
免责声明:我根本不是 webpack 专业人士,我是后端工程师而不是前端,所以我在 webpack 中引用的任何内容都可以写得比我正在做的要好得多
算术.js
const add = (a, b) => +a + +b;
const substract = (a, b) => +a - +b;
const multiply = (a, b) => a * b;
const divide = (a, b) => (b == '0' ? 'Err' : roundResult(a / b));
const roundResult = (n) => Math.round((n + Number.EPSILON) * 100) / 100; // Rounds n to 2 decimal places
module.exports = {
add,
subtract,
multiply,
divide,
roundResult
}
脚本.js
/* Math operations */
let equation = '0';
let previousEquation = '0';
let previousOperator = '';
const {add, substract, multiply, divide, roundResult} = require('./arithmetics');
const operate = (operator, a, b = a) => {
...
包.json
...
"scripts": {
...
"dev": "webpack --mode development",
"build": "webpack --mode production"
"test": "jest",
...
},
"devDependencies": {
"html-webpack-plugin": "^4.5.0",
"webpack": "^5.2.0",
"webpack-cli": "^4.1.0"
}
...
webpack.config.js
const HtmlWebpackPlugin = require("html-webpack-plugin");
const path = require('path');
module.exports = {
entry: './src/scripts.js',
output: {
filename: 'scripts.js',
path: path.resolve(__dirname, 'dist')
},
plugins: [
new HtmlWebpackPlugin({
title: "Webpack Output",
}),
],
};
测试.js
const { add } = require('./src/arithmetics');
test('adds 1 + 2 to equal 3', () => {
expect(add(1, 2)).toBe(3);
});
注意:我没有包含其代码的任何文件都应该保持不变
注意2:确保运行npm install
或yarn
安装包!
现在运行,应该会生成npm run build
一个名为的新文件夹。dist
从 srcindex.html
和style.css
dist 复制scripts.js
,这应该是您上传到服务器的内容(此步骤可以自动化,以便 dist 包含您的整个代码库,但我又不太了解 webpack)
要测试您的代码,您可以简单地运行npm test
上面的代码在我的本地机器上可以 100% 正常工作。
推荐阅读
- mongodb - 如果 slice 存在并且它包含至少一个设置为 true 的特定变量
- azure-devops - 将事件从 Azure DevOps 发布到 Azure 事件网格
- r - 使用 Tensorflow 在 R 中进行二进制图像解码
- javascript - Javascript对象值问题未定义
- c# - MVC ResetPasswordAsync 不能在不同的网站上工作
- javascript - 我可以为同一个图标使用 2 个不同的类吗?
- reactjs - 图片未显示但对本机反应有价值
- firebase - Firebase中实时数据库中的数据同步
- javascript - 对一个 onclick 事件使用两个 id
- c++ - C++ 模板继承可见性在派生类中丢失