news 2026/4/23 18:42:41

【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/4/23 14:32:24

jQuery EasyUI 树形菜单 - 创建带复选框的树形菜单

下面直接给你最实用、最常见的创建带复选框的树形菜单(Checkbox Tree)方法,jQuery EasyUI 的 tree 组件内置支持复选框,复制粘贴就能做出权限分配、部门多选、商品分类批量选择等场景,领导最爱的“勾选父节点自动勾选子…

作者头像 李华
网站建设 2026/4/23 13:03:03

jQuery EasyUI 树形菜单 - 树形菜单拖放控制

下面直接给你最实用、最常见的树形菜单拖放控制(Draggable & Droppable Tree)方法,jQuery EasyUI 的 tree 组件内置支持拖拽节点(移动节点、排序、跨树拖拽),复制粘贴就能用,领导最爱的“菜…

作者头像 李华
网站建设 2026/4/23 17:50:00

Codigger 的 AI 哲学:不仅是“生成”,更是“理解”

当市面上大多数 AI 编程工具仍停留在“根据提示词生成一段代码”的浅层辅助阶段时,Codigger 已提出一套更为深刻的 AI 赋能逻辑。这张架构图贯穿上下的“AI 大模型赋能”路径,揭示了其独特的“双向驱动”机制。1. 向下扎根:如同架构师般深度思…

作者头像 李华