/churn/snapshots/churn-tests-classes.rb
Ruby | 107 lines | 52 code | 23 blank | 32 comment | 0 complexity | 6f16f1c687a595a1ba441688de9dfd5d MD5 | raw file
- #---
- # Excerpted from "Everyday Scripting in Ruby"
- # We make no guarantees that this code is fit for any purpose.
- # Visit http://www.pragmaticprogrammer.com/titles/bmsft for more book information.
- #---
- require 'test/unit'
- require 'churn'
- # If I grouped the methods under test, it seems sensible to also group
- # the methods testing them, so I put them all inside their own test
- # class.
- class SubversionRepositoryTests < Test::Unit::TestCase
- # Each one of the repository test methods needs a repository. Each
- # one would create it exactly the same way. I can remove that
- # duplication by putting it in this setup method. Like methods
- # beginning with "test", it's special. Test::Unit knows to run it
- # before each test method.
- #
- # Since SubversionRepositoryTests is a class like any other, I can
- # use an instance variable to communicate the repository to the test
- # methods.
- def setup
- @repository = SubversionRepository.new('root')
- end
- def test_date
- assert_equal('2005-03-04',
- @repository.date(Time.local(2005, 3, 4)))
- end
- def test_subversion_log_can_have_no_changes
- assert_equal(0, @repository.extract_change_count_from("------------------------------------------------------------------------\n"))
- end
-
- def test_subversion_log_with_changes
- assert_equal(2, @repository.extract_change_count_from("------------------------------------------------------------------------\nr2531 | bem | 2005-07-01 01:11:44 -0500 (Fri, 01 Jul 2005) | 1 line\n\nrevisions up through ch 3 exercises\n------------------------------------------------------------------------\nr2524 | bem | 2005-06-30 18:45:59 -0500 (Thu, 30 Jun 2005) | 1 line\n\nresults of read-through; including renaming mistyping to snapshots\n------------------------------------------------------------------------\n"))
- end
- end
- class ChurnTests < Test::Unit::TestCase
- def test_month_before_is_28_days
- assert_equal(Time.local(2005, 1, 1),
- month_before(Time.local(2005, 1, 29)))
- end
- def test_header_format
- assert_equal("Changes since 2005-08-05:",
- header('2005-08-05'))
- end
- # The above test used to look like this:
- #
- # def test_header_format
- # assert_equal("Changes since 2005-08-05:",
- # header(svn_date(month_before(Time.local(2005, 9, 2)))))
- # end
- #
- # I could have changed it to create a SubversionRepository object
- # and use it to convert Ruby's Time to a date string, but it's not
- # really header's responsibility to convert a *Subversion* time; its
- # responsibility is really just to add formatting to whatever time
- # string is passed in, no matter what the format.
- #
- # I faced the same decision earlier and made the opposite choice. I
- # guess I was wrong one of the times.
- def test_normal_subsystem_line_format
- assert_equal(' audit ********* (45)',
- subsystem_line("audit", 45))
- end
- def test_asterisks_for_divides_by_five
- assert_equal('****', asterisks_for(20))
- end
- def test_asterisks_for_rounds_up_and_down
- assert_equal('****', asterisks_for(18))
- assert_equal('***', asterisks_for(17))
- end
- def test_churn_line_to_int_extracts_parenthesized_change_count
- assert_equal(19, churn_line_to_int(" ui2 **** (19)"))
- assert_equal(9, churn_line_to_int(" ui ** (9)"))
- end
- def test_order_by_descending_change_count
- original = [ "all that really matters is the number in parens - (1)",
- " inventory (0)",
- " ui ** (12)" ]
- expected = [ " ui ** (12)",
- "all that really matters is the number in parens - (1)",
- " inventory (0)" ]
- actual = order_by_descending_change_count(original)
- assert_equal(expected, actual)
- end
- end