Ruby 2.3.3 released
ruby-lang.orgRandom question, how is a regression like a 'no method error' possible? Don't the creators of these languages write extremely exhaustive tests? I don't know much about this, just wondering...
Looks to be a corner case not covered by existing tests prior to now.
“This release contains a bug fix about Refinements and Module#prepend. The mixture use of Module#refine and Module#prepend to the same Class could cause unexpected NoMethodError. This is a regression on Ruby 2.3.2 released last week. See [Bug #12920] for details.”
Presumably it was discovered in the wild, fixed, test cases written, and that fix was pushed. Time taken: 6 days. https://www.ruby-lang.org/en/news/2016/11/15/ruby-2-3-2-rele...
[Bug #12920] https://bugs.ruby-lang.org/issues/12920
Ok awesome, thanks for explaining!
Good article explaining complexity of refinements in Ruby: http://blog.headius.com/2012/11/refining-ruby.html
It isn't possible to write exhaustive tests - there are an infinite number of possible program states.
Well, finite bound by the width of your pointer type, which doesn't help much.
Can't some programs be proven to be partially or totally correct?
Using formal methods? Yes but as an industry we simply don't know how to scale that to something as large and unwieldy as the Ruby VM.
And even if we did, correct according to what? There is no mathematical model of the Ruby language to prove it equivalent to (there are a few semantic models for Ruby but they are very limited).
And even if we had that, the computational resources needed likely are not available.
There is rubyspec, but it doesn't cover all possible paths, just the ones that the developers deemed important enough to test.
What I am curious to know is _what_ does ruby use besides rubyspec? Do they run tests against the top 100, 1000, etc rubygems before releasing? I know other communities like Rust (and even Perl) do this kind of regression testing. While this won't catch all possible regressions it seems like a reasonable starting point to uncover issues before a release.
There has been quite a controversy about rubyspec afaik: the tldr is that the de-facto ruby spec is basically 'whatever piece of software capable of running rails'. This is because the ruby devs change stuff around very often and don't keep an official spec of the language, to the extent that the creator of rubyspec had given up.
This might have changed in the meantime, dunno.
https://github.com/rubinius/rubinius-archive/blob/cf54187d42...
To be honest the issues with rubyspec in the past were sociological more than anything else. It was a right pain making contributions, and certainly not a welcoming community.
Specs have been part of ruby core for quite a while now, thanks to the efforts of other members of the community.
it has indeed changed, the project has been reignited as "The Ruby Spec Suite".
It still doesn't cover everything, but it's used and contributed to by multiple implementations, and looks healthy https://github.com/ruby/spec/graphs/contributors
> Do they run tests against the top 100, 1000, etc rubygems before releasing?
I don't believe they do. They only recently started testing against ruby spec.
I work on an alternative implementation, and we are planning to test against literally all the gems in RubyGems ourselves. We test the top 100 or so at the moment.
If I might make a suggestion, I'd recommend doing some kind of tracing when you run the tests so you can have a mapping of what parts of your code are exercised by which gems/tests. Then when you make changes to your code you can run the tests that relate to that part of the system first, thus giving you more confidence that your change didn't cause a regression. This should be much more efficient than simply doing a full gem run (although I'd recommend that too, since it could uncover hidden dependencies).
ruby has always had its own set of tests, rubyspec is a very recent development.
Very recent? 2006, according to Wikipedia (https://en.wikipedia.org/wiki/RubySpec). That makes it about half the age of ruby.
Worse, Wikipedia claims
"The RubySpec project was discontinued at the end of 2014 due to a lack of uptake from mainstream ruby developers"
I don't understand what you're arguing against, given your own words say it didn't have uptake (in MRI) till 2014.
The project has been revived and adopted officially by MRI only in 2015. http://eregon.github.io/rubyspec/2015/07/29/rubyspec-is-rebo...
Is ruby dead? I would have expected more comments...
The release consists of only 6 commits, 3 of which are merges, 1 is tagging the version, 1 is updating the version.h header.
There's only one actual change, https://github.com/ruby/ruby/commit/a5d754acb8cfd6d3ac9f26b1...
Source: https://github.com/ruby/ruby/compare/v2_3_2...v2_3_3#diff-02...
It's just a patch release including a fix for a minor edge case.
There was the 2.3.2 release 6 days ago. There is not much to say about this release.
For a patch release?
What is the frequency of new ruby job posts these days, few and far between ?