news 2026/3/10 4:43:32

【MongoDB实战】8.3 简易商品管理系统-测试与优化 完善版

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【MongoDB实战】8.3 简易商品管理系统-测试与优化 完善版

《MongoDB实战入门》第8章 实战项目1:简易商品管理系统

8.3 简易商品管理系统-测试与优化 完善版

前置说明

本章实战基于Node.js + Mongoose操作MongoDB(需MongoDB 4.0+,事务依赖副本集),先完成基础环境准备:

    1. 安装依赖:npm install mongoose mocha chai --save-dev
    1. 启动MongoDB副本集(事务必备):参考MongoDB官方文档搭建单节点/多节点副本集,命名为rs0
    1. 基础数据模型(models/product.js):定义商品核心字段
// models/product.jsconstmongoose=require('mongoose');// 商品Schema定义constproductSchema=newmongoose.Schema({name:{type:String,required:true,trim:true},// 商品名称category:{type:String,required:true,trim:true},// 商品分类price:{type:Number,required:true,min:0},// 商品价格stock:{type:Number,required:true,min:0,default:0},// 库存(非负)createTime:{type:Date,default:Date.now},// 创建时间updateTime:{type:Date,default:Date.now}// 更新时间});// 预更新钩子:自动更新updateTime(适配高版本Mongoose,移除next参数)productSchema.pre('save',asyncfunction(){this.updateTime=Date.now();});// 导出模型constProduct=mongoose.model('Product',productSchema);module.exports=Product;
  1. MongoDB公共连接配置(utils/db.js,统一管理连接逻辑):
// utils/db.jsconstmongoose=require('mongoose');// 数据库连接配置(统一配置,避免重复编码)constDB_URI='mongodb://localhost:27017,localhost:27018,localhost:27019/product_manage?replicaSet=rs0';async functionconnectDB(){try{// 高版本Mongoose无需useNewUrlParser等废弃选项await mongoose.connect(DB_URI);console.log('MongoDB副本集连接成功');}catch(err){console.error('MongoDB连接失败:',err);process.exit(1);}}// 统一断开连接方法async functiondisconnectDB(){try{await mongoose.disconnect();console.log('MongoDB连接已断开');}catch(err){console.error('MongoDB断开连接失败:',err);}}module.exports={connectDB,disconnectDB};

8.3.1 功能测试:接口调用验证核心功能

测试目标

验证商品「新增、查询、更新库存、删除」核心接口的正确性,采用Mocha+Chai编写单元测试。

测试代码(test/product.test.js
constchai=require('chai');constexpect=chai.expect;constmongoose=require('mongoose');constProduct=require('../models/product');const{connectDB,disconnectDB}=require('../utils/db');// 全局前置:仅连接数据库,不全局清空数据before(async()=>{awaitconnectDB();});// 调整:仅清理测试用例生成的临时数据(不清理核心的10条商品数据)// 临时数据标识:名称包含「测试商品」「待删除商品」beforeEach(async()=>{await Product.deleteMany({name:{$in:['测试商品','待删除商品']}});});// 新增:每个用例结束后,仅清理当前用例的临时数据(进一步保证数据保留)afterEach(async()=>{await Product.deleteMany({name:{$in:['测试商品','待删除商品']}});});// 全局后置:仅断开数据库,不清理核心数据after(async()=>{awaitdisconnectDB();});// 测试套件:商品CRUD功能describe('商品管理系统核心功能测试',()=>{// 用例1:新增商品 - 批量生成10条核心数据(执行后保留)it
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/6 2:55:13

前端——跨平台桌面应用开发实践

Electron等技术让前端开发者能够构建跨平台桌面应用。本文将介绍桌面应用开发的关键技术点。 1 Electron基础架构 // 主进程 main.js const { app, BrowserWindow, ipcMain } require(electron) const path require(path)let mainWindowconst createWindow () > {mainWin…

作者头像 李华
网站建设 2026/3/9 20:55:48

OpenAI 的反击!GPT-5.2 强行拉开代差,Gemini 3 和 Claude 4 还有机会吗?

2025 年 12 月,全球 AI 领域爆发了一场足以载入史册的“圣诞闪击战”。 当谷歌的Gemini 3凭借其深度多模态能力刚刚在创意界站稳脚跟,Anthropic 的 Claude 4 靠着“软工程最强”的口碑收割开发者时,OpenAI 突然抛出了王牌——GPT-5.2。这不仅…

作者头像 李华
网站建设 2026/3/7 11:55:05

零售打工人加薪难?靠这张证,我在激烈竞争里站稳了脚跟

在零售商贸行业摸爬滚打三年,我深刻体会到“内卷”二字的重量。货架补货、客户接待、业绩冲刺,每天重复的工作占据了大部分时间,可薪资条上的数字却始终原地踏步。看着身边同事为了一个晋升名额争得头破血流,新人带着新鲜技能不断…

作者头像 李华