`
pupi
  • 浏览: 433634 次
  • 性别: Icon_minigender_1
社区版块
存档分类
最新评论

详解用radrails调试rails应用程序

阅读更多

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

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

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

http://richtextblog.blogspot.com/2006/09/radrails-all-is-forgiven.html<o:p></o:p>

http://www.misuse.org/cms/article.php?story=20060913182223765<o:p></o:p>

<o:p> </o:p>

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

<o:p> </o:p>

<1> 我的环境: windows xp + radrails<st1:chsdate year="1899" month="12" day="30" islunardate="False" isrocdate="False" w:st="on">0.7.2</st1:chsdate> + ruby1.8.5 + rails1.1.6 特别说明一下,ruby1.8.4用这个方法可能会有问题。所以请升级到ruby 1.8.5。(这里插几句,ruby for windows的升级比较讨厌的地方是,要将原来版本完全删除,再装新版本。这会导致railsmongrel等都要重新安装。不知道大家有没有更好的升级方法。)<o:p></o:p>

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

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

<o:p></o:p>

<v:shapetype id="_x0000_t75" coordsize="21600,21600" o:spt="75" o:preferrelative="t" path="m@4@5l@4@11@9@11@9@5xe" filled="f" stroked="f"><v:stroke joinstyle="miter"></v:stroke><v:formulas><v:f eqn="if lineDrawn pixelLineWidth 0"></v:f><v:f eqn="sum @0 1 0"></v:f><v:f eqn="sum 0 0 @1"></v:f><v:f eqn="prod @2 1 2"></v:f><v:f eqn="prod @3 21600 pixelWidth"></v:f><v:f eqn="prod @3 21600 pixelHeight"></v:f><v:f eqn="sum @0 0 1"></v:f><v:f eqn="prod @6 1 2"></v:f><v:f eqn="prod @7 21600 pixelWidth"></v:f><v:f eqn="sum @8 21600 0"></v:f><v:f eqn="prod @7 21600 pixelHeight"></v:f><v:f eqn="sum @10 21600 0"></v:f></v:formulas><v:path o:extrusionok="f" gradientshapeok="t" o:connecttype="rect"></v:path><o:lock v:ext="edit" aspectratio="t"></o:lock></v:shapetype><o:p></o:p>

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

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

-IC:\ruby\lib\ruby\gems\1.8\gems\rails-<st1:chsdate year="1899" month="12" day="30" islunardate="False" isrocdate="False" w:st="on">1.1.6</st1:chsdate>\bin<o:p></o:p>

如下图:

<o:p></o:p>

<o:p></o:p>

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

  <o:p></o:p>

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

<o:p></o:p>

<v:shapetype id="_x0000_t75" coordsize="21600,21600" o:spt="75" o:preferrelative="t" path="m@4@5l@4@11@9@11@9@5xe" filled="f" stroked="f"><v:stroke joinstyle="miter"></v:stroke><v:formulas><v:f eqn="if lineDrawn pixelLineWidth 0"></v:f><v:f eqn="sum @0 1 0"></v:f><v:f eqn="sum 0 0 @1"></v:f><v:f eqn="prod @2 1 2"></v:f><v:f eqn="prod @3 21600 pixelWidth"></v:f><v:f eqn="prod @3 21600 pixelHeight"></v:f><v:f eqn="sum @0 0 1"></v:f><v:f eqn="prod @6 1 2"></v:f><v:f eqn="prod @7 21600 pixelWidth"></v:f><v:f eqn="sum @8 21600 0"></v:f><v:f eqn="prod @7 21600 pixelHeight"></v:f><v:f eqn="sum @10 21600 0"></v:f></v:formulas><v:path o:extrusionok="f" gradientshapeok="t" o:connecttype="rect"></v:path><o:lock v:ext="edit" aspectratio="t"></o:lock></v:shapetype><o:p></o:p>

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

<o:p></o:p>

<o:p></o:p>

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

<o:p></o:p>

<o:p> </o:p>

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

<o:p></o:p>

<o:p> </o:p>

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

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

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

<o:p></o:p>

<o:p></o:p>

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

<13> 再补充几点:<o:p></o:p>

debug模式比正常的run模式慢不少,大家需要有点耐心。<o:p></o:p>

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

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

<o:p> </o:p>

 

分享到:
评论
20 楼 pupi 2007-05-30  
debug有个另外的好处,就是可以知道程序执行的过程,包括一些系统程序。
否则也不会每个完备的IDE都要提供这个功能了。
19 楼 robbin 2007-05-30  
无明 写道
ruby程序写测试有个问题,常发现测试代码比功能代码多的多,看着就有点郁闷了。


这很正常,根据我的估计,测试如果要完备,测试代码行数要差不多达到功能代码的两倍。当然这不是ruby的问题,如果你用Java,要达到完备的测试,也差不多是这样的比例,而且测试的效果还没有ruby这么好。
18 楼 无明 2007-05-30  
ruby程序写测试有个问题,常发现测试代码比功能代码多的多,看着就有点郁闷了。
17 楼 robbin 2007-05-30  
gigix说的对,我们也从来不需要用debugger。脚本语言编程没有那么复杂,根本不需要debug。
16 楼 gigix 2007-05-30  
写测试
我做Ruby/Rails开发这么久,根本就没用过debugger
15 楼 dazuiba 2007-05-30  
刚刚试了以下,太慢了,启动server要1分钟,走到断点更慢。脚本语言的通病,都很难debug
14 楼 pupi 2007-01-09  
dragon_zh 写道
我直接在debug下面进行,还是不行,是不是哪块设置不对?断点提前设好了


断点生效了没有? 浏览器是否可以看到结果?

如果断点生效了,可以在debug视图切换到ruby,再切回来看看。

radrails好像对刷新支持得不够好。
13 楼 dragon_zh 2007-01-09  
我直接在debug下面进行,还是不行,是不是哪块设置不对?断点提前设好了
12 楼 pupi 2007-01-05  
引用
我按照上面的配置了后,设置断点,然后debug,不能出现单步调试,页面停止不动,断点好象是起作用了,但是不能一步步调试,郁闷,啥原因呢


2个可能的原因:
1. 断点要提前设好。
2. 要注意切换透视图。比如你从rail透视图切换到debug,多试几次。
11 楼 dragon_zh 2007-01-05  
我按照上面的配置了后,设置断点,然后debug,不能出现单步调试,页面停止不动,断点好象是起作用了,但是不能一步步调试,郁闷,啥原因呢
10 楼 lighter 2007-01-01  
很少在radrails调试rails应用程序
试过几个IDE,最后还是选用了radrails,毕竟还可以,容易上手
9 楼 zhangzhaofeng 2006-12-31  
学习了....
8 楼 pupi 2006-12-31  
对rails测试代码的调试虽然不常用到,但是有时候也是有用的。这里将如何调试rails测试代码的方法也说明一下。

配置调试rails测试代码和配置调试rails本身的代码大同小异,只是前者要简单许多。

<1> 环境以及可运行的项目和配置调试rails完全一致,可以参考1楼。
<2> run菜单下选择debug.. ,会弹出下面的对话框:


在左侧的Test::Unit下建立一个新的测试项。这里叫product_test。看上面窗口的右边,有3个tab。
File Tab下,project下选择想要调试的项目,这里是depot;File输入或者选择想要调试的测试文件,Test Class下面输入测试类的名称。
Environment Tab下,选择合适的 ruby 解释器。可以参考1楼主贴的设置。
Common tab用默认的设置就可以了。
<3> 在测试文件中设置好断点,这里是product_test.rb(这一步可以提前做)。点击上面图右下角的Debug 按钮(也可以从工具条debug图标下的列表中选),就会进入单步调试状态了。

7 楼 pupi 2006-12-31  
sunsy 写道
调试模式是相当慢啊。

速度确实很慢。不过还在可以忍受的范围之内。
6 楼 sunsy 2006-12-29  
调试模式是相当慢啊。
5 楼 asalei 2006-12-29  
我也觉得radrails应该是比较好用的一个IDE,现在的一些问题在后续版本应该都能解决
4 楼 Jagie 2006-12-28  
看了楼主的帖子,正要下载0.7.2.可是由于海峡地震,访问不了国外官方主页,郁闷作罢
3 楼 pupi 2006-12-25  
sizhefang 写道
我的PC装的是radrails 0.7.1,按楼主说的配置方法,在选择debug
的项目时,点browse没有可选的项目.可我有一个可运行的hamster工程.郁闷!


在文本框直接输入工程名,应该也可以的。

另外,点击browse却没有可选的项目,可能是你没有将那个项目定义成 rails project或者ruby project ?
2 楼 sizhefang 2006-12-25  
我的PC装的是radrails 0.7.1,按楼主说的配置方法,在选择debug
的项目时,点browse没有可选的项目.可我有一个可运行的hamster工程.郁闷!
1 楼 alang 2006-12-25  
非常不错。

相关推荐

Global site tag (gtag.js) - Google Analytics