<body><script type="text/javascript"> function setAttributeOnload(object, attribute, val) { if(window.addEventListener) { window.addEventListener('load', function(){ object[attribute] = val; }, false); } else { window.attachEvent('onload', function(){ object[attribute] = val; }); } } </script> <div id="navbar-iframe-container"></div> <script type="text/javascript" src="https://apis.google.com/js/platform.js"></script> <script type="text/javascript"> gapi.load("gapi.iframes:gapi.iframes.style.bubble", function() { if (gapi.iframes && gapi.iframes.getContext) { gapi.iframes.getContext().openChild({ url: 'https://www.blogger.com/navbar.g?targetBlogID\x3d4684235500622716427\x26blogName\x3dCaiwangqin\x27s+blog\x26publishMode\x3dPUBLISH_MODE_HOSTED\x26navbarType\x3dBLUE\x26layoutType\x3dCLASSIC\x26searchRoot\x3dhttp://blog.caiwangqin.com/search\x26blogLocale\x3dzh_CN\x26v\x3d2\x26homepageUrl\x3dhttp://blog.caiwangqin.com/\x26vt\x3d3393395200455623441', where: document.getElementById("navbar-iframe-container"), id: "navbar-iframe", messageHandlersFilter: gapi.iframes.CROSS_ORIGIN_IFRAMES_FILTER, messageHandlers: { 'blogger-ping': function() {} } }); } }); </script>

Caiwangqin's blog

Focus on Life, Cloud Service, Smart Hardware, Architecture, Technic and beyond…

详解用radrails调试rails应用程序

2007年2月6日星期二









主帖: http://www.javaeye.com/topic/32669




javaer来说,程序可以debug,尤其是单步debug是很爽的。跟着“应用rails进行敏捷Web开发”的depot程序大概走了一遍,感觉很棒,代码量非常少。但是有些美中不足的是很多地方都是知其然而不知其所以然,如果可以一步步debugrails框架中去,应该可以更好地理解rails吧。带着这样的想法,开始找debug ror的方法。




javaeye中搜过一下,得到了一些线索,但是没有特别详细的文章介绍这个。根据这些线索,还有参考在radrails官方网站上的debug tag下的文章。我找到了下面2篇文章:




http://richtextblog.blogspot.com/2006/09/radrails-all-is-forgiven.html




http://www.misuse.org/cms/article.php?story=20060913182223765




 




根据这两篇文章的介绍(特别是第一篇),我成功地单步调试了depot程序。下面我将我的环境配置以及调试过程在这里描述一下:




 




<1> 我的环境: windows xp + radrails0.7.2 + ruby1.8.5 + rails1.1.6 特别说明一下,ruby1.8.4用这个方法可能会有问题。所以请升级到ruby 1.8.5。(这里插几句,ruby for windows的升级比较讨厌的地方是,要将原来版本完全删除,再装新版本。这会导致railsmongrel等都要重新安装。不知道大家有没有更好的升级方法。)




<2> 我的机器上已经有完整的depot工程了,可以正常运行。




<3> radrailsrun菜单中选debug..菜单项,会出现下面的对话框。










<4> 在左侧的ruby application下建立一个新的应用程序配置。这里叫Depot。看上面窗口的右边,有4tabFile Tab下,project下选择想要调试的项目,这里是depotFile输入script\server(应该是用来启动server的)




<5> Arguments tab下解释器文本框中输入:




-IC:\ruby\lib\ruby\gems\1.8\gems\rails-1.1.6\bin




如下图:










这里我的ruby装在 c:\ruby目录下。




 




<6> Environment Tab下,选择interpreter tab。选择合适的 ruby 解释器。如下图:










ruby解释器ee的定义在radrails windows菜单下的preference菜单项下,如下图:










<7> common tab中,确保选中复选框 allocate console,而不选 Launch in background。如下图:







 




<8> 至此,针对depot这个项目的debug配置已经全部完成了。现在可以在程序中设置断点了。我在 admin_controller.rb update方法中设置一个断点如下:







 




<9> 然后回到上面的那个debug菜单项,点击右下角的debug按钮,等待半分钟左右,控制台会显示以调试模式启动了webrick,假设是3000端口。




<10> 打开浏览器,访问 http://localhost:3000/admin/edit/20 。会出现Editing product的界面,product id 20。在界面最下面有一个edit按钮。点击该按钮,等待。。。




<11> 很酷,radrailsdebug 透视图中出现了单步调试的界面,如下图:










<12> 剩下的就和eclipse for java很类似了。有点不同的是,如果想要看某个变量,在代码窗口(上图中左中部)选中该变量,然后点击鼠标右键,选择inspect,该变量值就会出现在右上的Expressions的变量列表中了。




<13> 再补充几点:




debug模式比正常的run模式慢不少,大家需要有点耐心。




在用debug模式启动server之前,要先将断点设置好。在运行时设置新的断点好像不起作用。




radrails进入断点时有时候需要切换透视图,debug透视图好像不会主动刷新 L 希望后续的版本能改进。


 




Link to 详解用radrails调试rails应用程序


标签:

posted by Caiwangqin, 01:54

0 Comments:

发表评论

订阅 博文评论 [Atom]

<< 主页