news 2026/6/6 9:46:29

【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/6/5 10:47:24

jQuery EasyUI 树形菜单 - 创建基础树形网格

jQuery EasyUI 树形网格(TreeGrid) - 创建基础树形网格 jQuery EasyUI 的 TreeGrid(树形网格)是基于 DataGrid 扩展的组件,用于显示带有层级关系的表格数据。它结合了树视图(Tree)和可编辑网格…

作者头像 李华
网站建设 2026/5/30 2:34:24

jQuery EasyUI 树形菜单 - 树形网格添加分页

jQuery EasyUI 树形网格(TreeGrid) - 添加分页 jQuery EasyUI 的 TreeGrid 继承自 DataGrid,因此支持 pagination: true 属性来启用分页功能。但由于 TreeGrid 是层级结构,分页通常只针对顶级根节点进行(子节点通过动…

作者头像 李华
网站建设 2026/6/2 18:55:01

Kotaemon如何应对文化差异?本地化适配策略分析

Kotaemon如何应对文化差异?本地化适配策略分析 在智能客服系统走向全球的今天,一个看似简单的用户提问——“我能不能退货?”——背后可能隐藏着巨大的文化鸿沟。在日本,这或许是一句含蓄的情绪表达;在德国&#xff0c…

作者头像 李华
网站建设 2026/6/5 5:02:54

IM即时通讯系统:安全可控、功能全面的社交解决方案全解析

在数字化社交时代,即时通讯(IM)系统已成为社交平台的核心基础设施。本文将深入解析开源IM系统的核心优势与功能亮点,为开发者提供一套安全可控、功能全面的社交解决方案。一、核心优势:安全与性能的双重保障1. 独立数据…

作者头像 李华
网站建设 2026/6/3 10:24:24

扭蛋机小程序开发制作!

扭蛋机便是盲盒的另一种形式,目前国内消费市场主要集中在互联网上,玩家在手机上就可以体验抽盲盒的乐趣,因此线上盲盒扭蛋机小程序的出现也是顺应市场发展。扭蛋机里面的盲盒商品一般是手办等,盲盒种类繁多,玩家可以抽…

作者头像 李华