[#67346] Future of test suites for Ruby — Charles Oliver Nutter <headius@...>
I'll try to be brief so we can discuss all this. tl;dr: RubySpec is
19 messages
2015/01/05
[#67353] Re: Future of test suites for Ruby
— Tanaka Akira <akr@...>
2015/01/05
2015-01-06 7:18 GMT+09:00 Charles Oliver Nutter <headius@headius.com>:
[#67444] [ruby-trunk - Feature #10718] [Open] IO#close should not raise IOError on closed IO objects. — akr@...
Issue #10718 has been reported by Akira Tanaka.
3 messages
2015/01/09
[#67689] Keyword Arguments — Anthony Crumley <anthony.crumley@...>
Please forgive my ignorance as I am new to MRI development and am still
5 messages
2015/01/20
[#67733] [ruby-trunk - Bug #10761] Marshal.dump 100% slower in 2.2.0 vs 2.1.5 — normalperson@...
Issue #10761 has been updated by Eric Wong.
4 messages
2015/01/21
[#67736] Re: [ruby-trunk - Bug #10761] Marshal.dump 100% slower in 2.2.0 vs 2.1.5
— Eric Wong <normalperson@...>
2015/01/22
normalperson@yhbt.net wrote:
[#67772] Preventing Redundant Email Messages — Jeremy Evans <code@...>
For a long time, I've wondered why I sometimes receive redundant email
5 messages
2015/01/23
[ruby-core:67346] Future of test suites for Ruby
From:
Charles Oliver Nutter <headius@...>
Date:
2015-01-05 22:18:52 UTC
List:
ruby-core #67346
I'll try to be brief so we can discuss all this. tl;dr: RubySpec is valuable, MRI tests are valuable, we need to better utilize both of them. As you may have heard, Brian Shirai officially ended the RubySpec project last week: http://rubini.us/2014/12/31/matz-s-ruby-developers-don-t-use-rubyspec/ I believe this is a good opportunity for us to address concerns about how Ruby behavior is being tested over time. I think we can agree on the following facts: * ruby-core devs *have* been using RubySpec on and off, and at least some of us see value in continuing to do so. naruse already maintains a fork at github/naruse/rubyspec. * MRI's suite is not nearly as bad as the post claims. I have done some coverage measurements that show it doing at least as well as RubySpec for core classes, and significantly better for standard libraries. * MRI's tests are often hard to read, too large, undercommented. There's a lot of room for improvement, but this is obviously an organic codebase that has had many contributors. * Ugly tests are harder for users (and contributors) to grok. Ugly tests are less attractive targets for contribution. * RubySpec represents a valuable set of tests for Ruby behavior. There will be a large overlap with MRI's tests, but RubySpec does things that MRI's suite does not (and vice versa). * RubySpec is not gone; Rubinius will still need a suite to verify Ruby compatibility. RubySpec lives in the Rubinius repository now. There's a number of paths forward for us right now. * Do nothing. Run the last public RubySpec dump periodically to ensure we don't regress, as has been done with naruse's fork. New tests continue to go into MRI suite. This is the status quo, and I don't think anyone benefits from it other than folks who dislike change. * Begin an effort to bring missing tests from RubySpec into MRI's suite and to clean up and improve MRI's suite. Abandon RubySpec at some point. I think *some* effort should be made to improve MRI's suite in the short term, since we obviously aren't going to throw it away. I don't like the idea of spending a lot of time porting tests one way or the other...at least until we've picked a winner. I don't like the idea of abandoning RubySpec, since it has many valuable features. * Take over RubySpec as a fork and begin to maintain it as a secondary suite for MRI. Encourage contributors and committers to write specs rather than tests. I think this is possible. The barrier to contributing to RubySpec is much lower if we're maintaining a fork of it, and I think that eliminates many obstacles. I also feel like the future needs to be in either RubySpec or a much cleaner version of MRI's suite, and there's less work to start using the former now. ... So that's what I have for now. Give me your thoughts...anything goes.