今天要调试bug,先说明一下背景!有需求要修改keystonejs的后台管理页面,然后是看官方文档知道后台管理也是react+redux.然后为了加强后台管理页的功能(如汉化),然后将keystonejs的后台管理页面看完了。基本是可以看得动的。为了不破坏原来的功能且为了好用,就必须将原来
/Users/ivanlee/Documents/2018/work/szhealth/node_modules/.npminstall/keystone/4.0.0-beta.5/keystone/admin
中的代码移植到外面可用.在项目中的keystone.js中加入一些代码keystone.set('MY_ADMIN_PATH',process.env.MY_ADMIN_PATH || 'admin'); keystone.Admin = { Server: require('./admin/server'), }; keystone.set('pre:admin',function (app) { // console.log(keystone.get('MY_ADMIN_PATH'),'my_admin_path'); app.use('/' + keystone.get('MY_ADMIN_PATH'), require('./admin/server').createStaticRouter(keystone)); app.use('/' + keystone.get('MY_ADMIN_PATH'), require('./admin/server').createDynamicRouter(keystone)); })
- 然后在admin中加强自己的功能。但是发现,移植后的代码在详情页中修改页面不生效。
bug
,因为一开始就怀疑是自己的增强前端中代码改错了的问题。所以就自己将代码重新看一遍,验证自己的前端代码是没有问题的,代码输出的states和props都是符合要求的,然后再看admin中的后端代码,看了半天还是不知道错误再哪里。花了一个早上,确定了前端是没有问题的。 bug
解决还在继续。既然前端没问题那就是后端的问题啦--移植工程中的一些后端代码的改动。所以请教的后端同事。- 调试方法是:还原移植过程
在还原的过程中发现了有一个库被注释掉了了
`
// Use bodyParser and multer to parse request bodies and file uploads
router.use(bodyParser.json({}));
router.use(bodyParser.urlencoded({ extended: true }));
//router.use(multer({ includeEmptyFields: true }));
`
然后将注释掉的代码还原,报错。后端同事有经验的查看了
multer
的版本和keystonejs中的版本差别,然后将multer
的版本改成跟原来依赖中的一致。- 运行 问题完美解决
耗时 1 h
总结
- 在移植代码中要保持库的版本一致
- 代码移植中尽量不要注释自己看不懂的代码,即使注释了也要记下来,这往往是
bug
的起源 - 确认自己的代码范围没问题后。尽量找有经验的人帮忙debug吧。毕竟有些
bug
在有经验的人面前,就一句话的事
业精于勤荒于嬉,行成于思毁于随
共勉