quarry 0.4.0 → 0.5.0
Sign up to get free protection for your applications and to get access to all the features.
- data/CHANGES +22 -1
- data/MANIFEST +30 -339
- data/RELEASE +2 -4
- data/VERSION +1 -1
- data/bin/quarry +14 -10
- data/bin/quarry-doc +2 -2
- data/lib/quarry/assertion.rb +27 -0
- data/lib/quarry/{spec/config.rb → config.rb} +0 -0
- data/lib/quarry/document/template.rhtml +239 -0
- data/lib/quarry/document.rb +126 -0
- data/lib/quarry/expectation.rb +60 -0
- data/lib/quarry/extract.rb +2 -0
- data/lib/quarry/grammar/assert.rb +48 -0
- data/lib/quarry/grammar/expect.rb +114 -0
- data/lib/quarry/grammar/legacy/assert.rb +280 -0
- data/lib/quarry/grammar/should.rb +50 -0
- data/lib/quarry/grammar.rb +4 -0
- data/lib/quarry/{spec → markup}/step.rb +4 -3
- data/lib/quarry/markup.rb +70 -0
- data/lib/quarry/{stub/mock.rb → mock.rb} +1 -1
- data/lib/quarry/{loadmonitor.rb → monitor.rb} +0 -0
- data/lib/quarry/{stub/probe.rb → probe.rb} +8 -35
- data/lib/quarry/reporter/dotprogress.rb +62 -0
- data/lib/quarry/reporter/summary.rb +70 -0
- data/lib/quarry/reporter/verbatim.rb +82 -0
- data/lib/quarry/reporter.rb +70 -0
- data/lib/quarry/{spec → runner}/context.rb +7 -2
- data/lib/quarry/runner.rb +123 -0
- data/lib/quarry/{stub/stub.rb → stub.rb} +1 -1
- data/lib/quarry.rb +10 -0
- data/spec/basic.rd +0 -2
- data/spec/complex.rd +0 -2
- data/spec/mock.rd +20 -26
- data/spec/stub.rd +8 -12
- metadata +48 -361
- data/bin/ruby-break +0 -10
- data/doc/assets/images/clipboard.jpg +0 -0
- data/doc/assets/images/clipboard2.png +0 -0
- data/doc/assets/images/darksilver.png +0 -0
- data/doc/assets/images/icon/book.jpg +0 -0
- data/doc/assets/images/icon/download.gif +0 -0
- data/doc/assets/images/icon/letter_r.png +0 -0
- data/doc/assets/images/icon/license.png +0 -0
- data/doc/assets/images/icon/software.png +0 -0
- data/doc/assets/images/icon/source.png +0 -0
- data/doc/assets/images/miner.jpg +0 -0
- data/doc/assets/images/rbrylmtrx.png +0 -0
- data/doc/assets/images/ruby.gif +0 -0
- data/doc/assets/images/runneth.png +0 -0
- data/doc/assets/images/silver.gif +0 -0
- data/doc/assets/images/test.jpg +0 -0
- data/doc/assets/jquery/jquery.js +0 -1
- data/doc/assets/jquery/jquery.tabs.js +0 -1
- data/doc/assets/rdoc_ad.html +0 -12
- data/doc/assets/styles/index.css +0 -138
- data/doc/guide/stubs.md +0 -125
- data/doc/index.html +0 -285
- data/doc/log/bstats/stats.html +0 -39
- data/doc/log/notes.xml +0 -32
- data/doc/log/stats.html +0 -25
- data/doc/log/stats.log +0 -14
- data/doc/log/syntax.log +0 -0
- data/doc/rdoc/classes/Assertion/False.html +0 -177
- data/doc/rdoc/classes/Assertion/True.html +0 -152
- data/doc/rdoc/classes/Assertion.html +0 -171
- data/doc/rdoc/classes/Kernel.html +0 -105
- data/doc/rdoc/classes/Method.html +0 -168
- data/doc/rdoc/classes/Object.html +0 -507
- data/doc/rdoc/classes/Quarry/Break.html +0 -231
- data/doc/rdoc/classes/Quarry/Command.html +0 -443
- data/doc/rdoc/classes/Quarry/Extract.html +0 -215
- data/doc/rdoc/classes/Quarry/MethodProbe.html +0 -325
- data/doc/rdoc/classes/Quarry/Mock/Delegator.html +0 -179
- data/doc/rdoc/classes/Quarry/Mock/Setter.html +0 -175
- data/doc/rdoc/classes/Quarry/Mock.html +0 -233
- data/doc/rdoc/classes/Quarry/Spec/Comment.html +0 -237
- data/doc/rdoc/classes/Quarry/Spec/Config.html +0 -257
- data/doc/rdoc/classes/Quarry/Spec/Context.html +0 -154
- data/doc/rdoc/classes/Quarry/Spec/Document.html +0 -382
- data/doc/rdoc/classes/Quarry/Spec/Header.html +0 -195
- data/doc/rdoc/classes/Quarry/Spec/Macro.html +0 -166
- data/doc/rdoc/classes/Quarry/Spec/Markup.html +0 -279
- data/doc/rdoc/classes/Quarry/Spec/Reporter/DotProgress.html +0 -234
- data/doc/rdoc/classes/Quarry/Spec/Reporter/Summary.html +0 -294
- data/doc/rdoc/classes/Quarry/Spec/Reporter/Verbatim.html +0 -311
- data/doc/rdoc/classes/Quarry/Spec/Runner.html +0 -352
- data/doc/rdoc/classes/Quarry/Spec/Step.html +0 -190
- data/doc/rdoc/classes/Quarry/Spec/Template.html +0 -205
- data/doc/rdoc/classes/Quarry/Stub/Delegator.html +0 -179
- data/doc/rdoc/classes/Quarry/Stub/Setter.html +0 -175
- data/doc/rdoc/classes/Quarry/Stub.html +0 -224
- data/doc/rdoc/classes/Quarry.html +0 -176
- data/doc/rdoc/created.rid +0 -1
- data/doc/rdoc/files/CHANGES.html +0 -150
- data/doc/rdoc/files/COPYING.html +0 -468
- data/doc/rdoc/files/README.html +0 -195
- data/doc/rdoc/files/RELEASE.html +0 -122
- data/doc/rdoc/files/VERSION.html +0 -107
- data/doc/rdoc/files/bin/quarry-doc.html +0 -109
- data/doc/rdoc/files/bin/quarry.html +0 -109
- data/doc/rdoc/files/bin/ruby-break.html +0 -108
- data/doc/rdoc/files/bin/ruby-xacto.html +0 -101
- data/doc/rdoc/files/lib/quarry/assert_rb.html +0 -155
- data/doc/rdoc/files/lib/quarry/break_rb.html +0 -101
- data/doc/rdoc/files/lib/quarry/extract_rb.html +0 -108
- data/doc/rdoc/files/lib/quarry/loadmonitor_rb.html +0 -101
- data/doc/rdoc/files/lib/quarry/spec/config_rb.html +0 -101
- data/doc/rdoc/files/lib/quarry/spec/context_rb.html +0 -101
- data/doc/rdoc/files/lib/quarry/spec/document_rb.html +0 -111
- data/doc/rdoc/files/lib/quarry/spec/markup_rb.html +0 -108
- data/doc/rdoc/files/lib/quarry/spec/reporter/dotprogress_rb.html +0 -108
- data/doc/rdoc/files/lib/quarry/spec/reporter/summary_rb.html +0 -108
- data/doc/rdoc/files/lib/quarry/spec/reporter/verbatim_rb.html +0 -108
- data/doc/rdoc/files/lib/quarry/spec/reporter_rb.html +0 -109
- data/doc/rdoc/files/lib/quarry/spec/runner_rb.html +0 -109
- data/doc/rdoc/files/lib/quarry/spec/step_rb.html +0 -101
- data/doc/rdoc/files/lib/quarry/spec/template_rhtml.html +0 -228
- data/doc/rdoc/files/lib/quarry/spec_rb.html +0 -113
- data/doc/rdoc/files/lib/quarry/stub/mock_rb.html +0 -101
- data/doc/rdoc/files/lib/quarry/stub/probe_rb.html +0 -122
- data/doc/rdoc/files/lib/quarry/stub/spec_txt.html +0 -118
- data/doc/rdoc/files/lib/quarry/stub/stub_rb.html +0 -101
- data/doc/rdoc/fr_class_index.html +0 -56
- data/doc/rdoc/fr_file_index.html +0 -55
- data/doc/rdoc/fr_method_index.html +0 -117
- data/doc/rdoc/index.html +0 -24
- data/doc/rdoc/rdoc-style.css +0 -208
- data/doc/ri/Assertion/False/assert-i.yaml +0 -10
- data/doc/ri/Assertion/False/cdesc-False.yaml +0 -21
- data/doc/ri/Assertion/False/message-i.yaml +0 -10
- data/doc/ri/Assertion/True/assert-i.yaml +0 -11
- data/doc/ri/Assertion/True/cdesc-True.yaml +0 -26
- data/doc/ri/Assertion/True/message-c.yaml +0 -11
- data/doc/ri/Assertion/True/message-i.yaml +0 -11
- data/doc/ri/Assertion/True/method_missing-i.yaml +0 -12
- data/doc/ri/Assertion/True/new-c.yaml +0 -11
- data/doc/ri/Assertion/cdesc-Assertion.yaml +0 -40
- data/doc/ri/Kernel/cdesc-Kernel.yaml +0 -15
- data/doc/ri/Method/cdesc-Method.yaml +0 -18
- data/doc/ri/Method/migration-i.yaml +0 -12
- data/doc/ri/Method/signature-i.yaml +0 -12
- data/doc/ri/Object/assert%21-i.yaml +0 -17
- data/doc/ri/Object/assert-i.yaml +0 -15
- data/doc/ri/Object/assert_raises%21-i.yaml +0 -12
- data/doc/ri/Object/assert_raises-i.yaml +0 -15
- data/doc/ri/Object/cdesc-Object.yaml +0 -42
- data/doc/ri/Object/mock-i.yaml +0 -12
- data/doc/ri/Object/refute-i.yaml +0 -13
- data/doc/ri/Object/refute_raises-i.yaml +0 -17
- data/doc/ri/Object/remove-i.yaml +0 -12
- data/doc/ri/Object/should-i.yaml +0 -12
- data/doc/ri/Object/should_not-i.yaml +0 -12
- data/doc/ri/Object/should_not_raise-i.yaml +0 -12
- data/doc/ri/Object/should_raise-i.yaml +0 -12
- data/doc/ri/Object/stub-i.yaml +0 -12
- data/doc/ri/Quarry/Break/cdesc-Break.yaml +0 -23
- data/doc/ri/Quarry/Break/edit-i.yaml +0 -11
- data/doc/ri/Quarry/Break/new-c.yaml +0 -11
- data/doc/ri/Quarry/Extract/cdesc-Extract.yaml +0 -26
- data/doc/ri/Quarry/Extract/create_test-i.yaml +0 -12
- data/doc/ri/Quarry/Extract/extract_test_from_file-i.yaml +0 -12
- data/doc/ri/Quarry/Extract/test_extract-i.yaml +0 -18
- data/doc/ri/Quarry/MethodProbe/cdesc-MethodProbe.yaml +0 -46
- data/doc/ri/Quarry/MethodProbe/duckcall-c.yaml +0 -10
- data/doc/ri/Quarry/MethodProbe/initialize_copy-i.yaml +0 -10
- data/doc/ri/Quarry/MethodProbe/method_missing-i.yaml +0 -10
- data/doc/ri/Quarry/MethodProbe/new-c.yaml +0 -10
- data/doc/ri/Quarry/Mock/Delegator/cdesc-Delegator.yaml +0 -20
- data/doc/ri/Quarry/Mock/Delegator/method_missing-i.yaml +0 -10
- data/doc/ri/Quarry/Mock/Delegator/new-c.yaml +0 -10
- data/doc/ri/Quarry/Mock/Setter/%3d%3d-i.yaml +0 -10
- data/doc/ri/Quarry/Mock/Setter/cdesc-Setter.yaml +0 -18
- data/doc/ri/Quarry/Mock/Setter/new-c.yaml +0 -10
- data/doc/ri/Quarry/Mock/__table__-i.yaml +0 -11
- data/doc/ri/Quarry/Mock/cdesc-Mock.yaml +0 -25
- data/doc/ri/Quarry/Mock/method_missing-i.yaml +0 -12
- data/doc/ri/Quarry/Mock/new-c.yaml +0 -10
- data/doc/ri/Quarry/Spec/Comment/cdesc-Comment.yaml +0 -33
- data/doc/ri/Quarry/Spec/Comment/macro%3f-i.yaml +0 -12
- data/doc/ri/Quarry/Spec/Comment/new-c.yaml +0 -10
- data/doc/ri/Quarry/Spec/Comment/type-i.yaml +0 -12
- data/doc/ri/Quarry/Spec/Config/after-i.yaml +0 -12
- data/doc/ri/Quarry/Spec/Config/after_spec-i.yaml +0 -12
- data/doc/ri/Quarry/Spec/Config/before-i.yaml +0 -12
- data/doc/ri/Quarry/Spec/Config/before_spec-i.yaml +0 -12
- data/doc/ri/Quarry/Spec/Config/cdesc-Config.yaml +0 -26
- data/doc/ri/Quarry/Spec/Config/new-c.yaml +0 -10
- data/doc/ri/Quarry/Spec/Context/cdesc-Context.yaml +0 -21
- data/doc/ri/Quarry/Spec/Context/new-c.yaml +0 -10
- data/doc/ri/Quarry/Spec/Document/cdesc-Document.yaml +0 -76
- data/doc/ri/Quarry/Spec/Document/generate-i.yaml +0 -12
- data/doc/ri/Quarry/Spec/Document/new-c.yaml +0 -12
- data/doc/ri/Quarry/Spec/Document/quiet%3f-i.yaml +0 -12
- data/doc/ri/Quarry/Spec/Document/require_rdoc-i.yaml +0 -11
- data/doc/ri/Quarry/Spec/Document/save-i.yaml +0 -12
- data/doc/ri/Quarry/Spec/Document/template-i.yaml +0 -12
- data/doc/ri/Quarry/Spec/Header/cdesc-Header.yaml +0 -30
- data/doc/ri/Quarry/Spec/Header/new-c.yaml +0 -10
- data/doc/ri/Quarry/Spec/Macro/cdesc-Macro.yaml +0 -22
- data/doc/ri/Quarry/Spec/Macro/new-c.yaml +0 -10
- data/doc/ri/Quarry/Spec/Markup/cdesc-Markup.yaml +0 -31
- data/doc/ri/Quarry/Spec/Markup/description-i.yaml +0 -11
- data/doc/ri/Quarry/Spec/Markup/new-c.yaml +0 -11
- data/doc/ri/Quarry/Spec/Markup/parse-i.yaml +0 -11
- data/doc/ri/Quarry/Spec/Markup/parse_section-i.yaml +0 -11
- data/doc/ri/Quarry/Spec/Reporter/DotProgress/cdesc-DotProgress.yaml +0 -21
- data/doc/ri/Quarry/Spec/Reporter/DotProgress/report_intro-i.yaml +0 -10
- data/doc/ri/Quarry/Spec/Reporter/DotProgress/report_step-i.yaml +0 -10
- data/doc/ri/Quarry/Spec/Reporter/DotProgress/report_summary-i.yaml +0 -16
- data/doc/ri/Quarry/Spec/Reporter/Summary/cdesc-Summary.yaml +0 -31
- data/doc/ri/Quarry/Spec/Reporter/Summary/report_comment-i.yaml +0 -10
- data/doc/ri/Quarry/Spec/Reporter/Summary/report_error-i.yaml +0 -10
- data/doc/ri/Quarry/Spec/Reporter/Summary/report_fail-i.yaml +0 -10
- data/doc/ri/Quarry/Spec/Reporter/Summary/report_header-i.yaml +0 -10
- data/doc/ri/Quarry/Spec/Reporter/Summary/report_macro-i.yaml +0 -10
- data/doc/ri/Quarry/Spec/Reporter/Summary/report_pass-i.yaml +0 -10
- data/doc/ri/Quarry/Spec/Reporter/Verbatim/cdesc-Verbatim.yaml +0 -29
- data/doc/ri/Quarry/Spec/Reporter/Verbatim/report_comment-i.yaml +0 -10
- data/doc/ri/Quarry/Spec/Reporter/Verbatim/report_error-i.yaml +0 -10
- data/doc/ri/Quarry/Spec/Reporter/Verbatim/report_fail-i.yaml +0 -10
- data/doc/ri/Quarry/Spec/Reporter/Verbatim/report_header-i.yaml +0 -16
- data/doc/ri/Quarry/Spec/Reporter/Verbatim/report_macro-i.yaml +0 -10
- data/doc/ri/Quarry/Spec/Reporter/Verbatim/report_pass-i.yaml +0 -10
- data/doc/ri/Quarry/Spec/Reporter/cdesc-Reporter.yaml +0 -20
- data/doc/ri/Quarry/Spec/Runner/cdesc-Runner.yaml +0 -47
- data/doc/ri/Quarry/Spec/Runner/check-i.yaml +0 -12
- data/doc/ri/Quarry/Spec/Runner/check_spec-i.yaml +0 -12
- data/doc/ri/Quarry/Spec/Runner/new-c.yaml +0 -12
- data/doc/ri/Quarry/Spec/Runner/run_step-i.yaml +0 -12
- data/doc/ri/Quarry/Spec/Step/cdesc-Step.yaml +0 -30
- data/doc/ri/Quarry/Spec/Step/new-c.yaml +0 -10
- data/doc/ri/Quarry/Spec/Template/cdesc-Template.yaml +0 -31
- data/doc/ri/Quarry/Spec/Template/new-c.yaml +0 -11
- data/doc/ri/Quarry/Spec/Template/parse_template-i.yaml +0 -10
- data/doc/ri/Quarry/Spec/cdesc-Spec.yaml +0 -15
- data/doc/ri/Quarry/Stub/Delegator/cdesc-Delegator.yaml +0 -20
- data/doc/ri/Quarry/Stub/Delegator/method_missing-i.yaml +0 -10
- data/doc/ri/Quarry/Stub/Delegator/new-c.yaml +0 -10
- data/doc/ri/Quarry/Stub/Setter/%3d%3d-i.yaml +0 -10
- data/doc/ri/Quarry/Stub/Setter/cdesc-Setter.yaml +0 -18
- data/doc/ri/Quarry/Stub/Setter/new-c.yaml +0 -10
- data/doc/ri/Quarry/Stub/__table__-i.yaml +0 -11
- data/doc/ri/Quarry/Stub/cdesc-Stub.yaml +0 -23
- data/doc/ri/Quarry/Stub/method_missing-i.yaml +0 -11
- data/doc/ri/Quarry/Stub/new-c.yaml +0 -10
- data/doc/ri/Quarry/cdesc-Quarry.yaml +0 -16
- data/doc/ri/created.rid +0 -1
- data/doc/spec/stub.html +0 -394
- data/lib/quarry/assert.rb +0 -198
- data/lib/quarry/break.rb +0 -51
- data/lib/quarry/spec/document.rb +0 -130
- data/lib/quarry/spec/markup.rb +0 -85
- data/lib/quarry/spec/reporter/dotprogress.rb +0 -66
- data/lib/quarry/spec/reporter/summary.rb +0 -74
- data/lib/quarry/spec/reporter/verbatim.rb +0 -87
- data/lib/quarry/spec/reporter.rb +0 -74
- data/lib/quarry/spec/runner.rb +0 -127
- data/lib/quarry/spec/template.rhtml +0 -116
- data/lib/quarry/spec.rb +0 -7
- data/lib/quarry/stub/spec.txt +0 -113
- data/work/consider/document.rb +0 -35
- data/work/consider/fixture.rb +0 -153
- data/work/deprecated/assert/must.rb +0 -9
- data/work/deprecated/assert/should.rb +0 -9
- data/work/deprecated/build.rb +0 -82
- data/work/deprecated/mock/file.rb +0 -11
- data/work/deprecated/mock/mock.0.rb +0 -77
- data/work/deprecated/overlay.rb +0 -64
- data/work/deprecated/spec.rb +0 -195
- data/work/deprecated/stub/stub.0.rb +0 -180
- data/work/deprecated/stub/stub.1.rb +0 -114
- data/work/deprecated/stub/test_stub.rb +0 -66
- data/work/deprecated/test/case.rb +0 -141
- data/work/sandbox/assert.rb +0 -100
- data/work/sandbox/bug.rb +0 -49
- data/work/sandbox/build/announce.rb +0 -213
- data/work/sandbox/build/check.rb +0 -109
- data/work/sandbox/build/gem.rb +0 -235
- data/work/sandbox/build/make.rb +0 -118
- data/work/sandbox/build/manpage.rb +0 -201
- data/work/sandbox/build/notes.rb +0 -214
- data/work/sandbox/build/pack.rb +0 -228
- data/work/sandbox/build/rdoc.rb +0 -289
- data/work/sandbox/build/rubyforge.rb +0 -91
- data/work/sandbox/build/sign.rb +0 -241
- data/work/sandbox/build/stamp.rb +0 -37
- data/work/sandbox/build/stats.rb +0 -154
- data/work/sandbox/build/svn.rb +0 -193
- data/work/sandbox/build/test.rb +0 -521
- data/work/sandbox/design.rb +0 -200
- data/work/sandbox/iface_scanner.rb +0 -102
- data/work/sandbox/testunit/assertions/assert_has_keys.rb +0 -38
- data/work/sandbox/testunit/assertions/assert_has_only_keys.rb +0 -38
- data/work/sandbox/testunit/unit.rb +0 -104
- data/work/sandbox/unitspec.rb +0 -54
- data/work/sandbox/x_isotest.rb +0 -532
@@ -1,102 +0,0 @@
|
|
1
|
-
|
2
|
-
module Quarry
|
3
|
-
|
4
|
-
module Documentation
|
5
|
-
|
6
|
-
class RubyCollector
|
7
|
-
|
8
|
-
def initialize(*paths)
|
9
|
-
@classes = []
|
10
|
-
@modules = []
|
11
|
-
end
|
12
|
-
|
13
|
-
def collect
|
14
|
-
ObjectSpace.each_object(Class) do |reference|
|
15
|
-
@classes << ClassSpecification.new(reference)
|
16
|
-
end
|
17
|
-
|
18
|
-
ObjectSpace.each_object(Module) do |reference|
|
19
|
-
@modules << ModuleSpecification.new(reference)
|
20
|
-
end
|
21
|
-
end
|
22
|
-
|
23
|
-
def to_xml
|
24
|
-
inner = []
|
25
|
-
inner << to_xml_for_modules
|
26
|
-
inner << to_xml_for_classes
|
27
|
-
inner = inner.join("\n")
|
28
|
-
|
29
|
-
xml = %{<ruby-program>\n#{inner}\n</ruby-program>}
|
30
|
-
end
|
31
|
-
|
32
|
-
def to_xml_for_classes
|
33
|
-
template = <<-END
|
34
|
-
<class name="%s">
|
35
|
-
</class>
|
36
|
-
END
|
37
|
-
inner = []
|
38
|
-
@classes.each do
|
39
|
-
inner << template % [ reference.name ]
|
40
|
-
end
|
41
|
-
inner = inner.join("\n")
|
42
|
-
classes_xml = %{<classes>\n#{inner}\n</classes>}
|
43
|
-
end
|
44
|
-
|
45
|
-
def to_xml_for_modules
|
46
|
-
template = <<-END
|
47
|
-
<module name="%s">
|
48
|
-
</module>
|
49
|
-
END
|
50
|
-
inner = []
|
51
|
-
@modules.each do
|
52
|
-
inner << template % [ reference.name ]
|
53
|
-
end
|
54
|
-
inner = inner.join("\n")
|
55
|
-
classes_xml = %{<modules>\n#{inner}\n</modules>}
|
56
|
-
end
|
57
|
-
|
58
|
-
end
|
59
|
-
|
60
|
-
#
|
61
|
-
|
62
|
-
class ModuleSpecification
|
63
|
-
attr :reference
|
64
|
-
|
65
|
-
def initialize(reference)
|
66
|
-
@reference = reference
|
67
|
-
end
|
68
|
-
|
69
|
-
def public_instance_methods
|
70
|
-
reference.public_instance_methods(false)
|
71
|
-
end
|
72
|
-
|
73
|
-
def private_instance_methods
|
74
|
-
reference.private_instance_methods(false)
|
75
|
-
end
|
76
|
-
|
77
|
-
def protected_instance_methods
|
78
|
-
reference.protected_instance_methods(false)
|
79
|
-
end
|
80
|
-
|
81
|
-
def public_methods
|
82
|
-
reference.public_methods(false)
|
83
|
-
end
|
84
|
-
|
85
|
-
def private_methods
|
86
|
-
reference.private_methods(false)
|
87
|
-
end
|
88
|
-
|
89
|
-
def protected_methods
|
90
|
-
reference.protected_methods(false)
|
91
|
-
end
|
92
|
-
|
93
|
-
end
|
94
|
-
|
95
|
-
#
|
96
|
-
|
97
|
-
class ClassSpecification < ModuleSpecification
|
98
|
-
end
|
99
|
-
|
100
|
-
end
|
101
|
-
|
102
|
-
end
|
@@ -1,38 +0,0 @@
|
|
1
|
-
require 'facets/core/hash/has_keys'
|
2
|
-
|
3
|
-
class Hash
|
4
|
-
|
5
|
-
# Returns true is hash has the given keys,
|
6
|
-
# otherwise throws an ArgumentError.
|
7
|
-
#
|
8
|
-
# h = { :a => 1, :b => 2 }
|
9
|
-
# h.assert_has_keys( :a ) #=> true
|
10
|
-
# h.assert_has_keys( :c ) #=> ArgumentError
|
11
|
-
#
|
12
|
-
def assert_has_keys(*check_keys)
|
13
|
-
raise(ArgumentError, "does not have key(s)") unless has_keys?(*check_keys)
|
14
|
-
end
|
15
|
-
|
16
|
-
end
|
17
|
-
|
18
|
-
|
19
|
-
# _____ _
|
20
|
-
# |_ _|__ ___| |_
|
21
|
-
# | |/ _ \/ __| __|
|
22
|
-
# | | __/\__ \ |_
|
23
|
-
# |_|\___||___/\__|
|
24
|
-
#
|
25
|
-
=begin test
|
26
|
-
|
27
|
-
require 'test/unit'
|
28
|
-
|
29
|
-
class TCHash < Test::Unit::TestCase
|
30
|
-
|
31
|
-
def test_assert_has_keys
|
32
|
-
assert_nothing_raised { { :a=>1,:b=>2,:c=>3 }.assert_has_keys(:a,:b) }
|
33
|
-
assert_raises( ArgumentError ) { { :a=>1,:b=>2,:c=>3 }.assert_has_keys(:d) }
|
34
|
-
end
|
35
|
-
|
36
|
-
end
|
37
|
-
|
38
|
-
=end
|
@@ -1,38 +0,0 @@
|
|
1
|
-
require 'facets/core/hash/has_only_keys'
|
2
|
-
|
3
|
-
class Hash
|
4
|
-
|
5
|
-
# Returns true is hash has only then given keys,
|
6
|
-
# otherwise throws an ArgumentError.
|
7
|
-
#
|
8
|
-
# h = { :a => 1, :b => 2 }
|
9
|
-
# h.assert_has_only_keys( :a, :b ) #=> true
|
10
|
-
# h.assert_has_only_keys( :a ) #=> ArgumentError
|
11
|
-
#
|
12
|
-
def assert_has_only_keys(*check_keys)
|
13
|
-
raise(ArgumentError, "has unexpected key(s)") unless has_only_keys?(*check_keys)
|
14
|
-
end
|
15
|
-
|
16
|
-
end
|
17
|
-
|
18
|
-
|
19
|
-
# _____ _
|
20
|
-
# |_ _|__ ___| |_
|
21
|
-
# | |/ _ \/ __| __|
|
22
|
-
# | | __/\__ \ |_
|
23
|
-
# |_|\___||___/\__|
|
24
|
-
#
|
25
|
-
=begin test
|
26
|
-
|
27
|
-
require 'test/unit'
|
28
|
-
|
29
|
-
class TCHash < Test::Unit::TestCase
|
30
|
-
|
31
|
-
def test_assert_has_only_keys
|
32
|
-
assert_nothing_raised { { :a=>1,:b=>2,:c=>3 }.assert_has_only_keys(:a,:b,:c) }
|
33
|
-
assert_raises( ArgumentError ) { { :a=>1,:b=>2,:c=>3 }.assert_has_only_keys(:a,:b) }
|
34
|
-
end
|
35
|
-
|
36
|
-
end
|
37
|
-
|
38
|
-
=end
|
@@ -1,104 +0,0 @@
|
|
1
|
-
#
|
2
|
-
# Totally minimal (hopefully) drop-in replacement for test/unit
|
3
|
-
#
|
4
|
-
|
5
|
-
# TODO: document minimal core methods needed for this to work
|
6
|
-
|
7
|
-
at_exit { Test::Unit.autotest }
|
8
|
-
|
9
|
-
module Test #:nodoc: all
|
10
|
-
class Assertion < Exception; end
|
11
|
-
|
12
|
-
class Unit
|
13
|
-
VERSION = "1.0.0"
|
14
|
-
|
15
|
-
def self.autotest
|
16
|
-
ObjectSpace.each_object(Class) do |klass|
|
17
|
-
next unless klass < Test::Unit::TestCase
|
18
|
-
inst = klass.new
|
19
|
-
klass.public_instance_methods(true).each do |meth|
|
20
|
-
next unless meth.index("test") == 0
|
21
|
-
begin
|
22
|
-
inst.setup
|
23
|
-
inst.send meth.intern
|
24
|
-
inst.teardown
|
25
|
-
rescue Exception => e
|
26
|
-
# TODO: make output compatible with unit_diff
|
27
|
-
print "\n", (Test::Assertion === e ? "Failure: " : "Error: ")
|
28
|
-
puts "#{klass}.#{meth}: #{e}"
|
29
|
-
puts e.backtrace
|
30
|
-
end
|
31
|
-
end
|
32
|
-
end
|
33
|
-
end
|
34
|
-
|
35
|
-
class TestCase
|
36
|
-
def setup; end
|
37
|
-
def teardown; end
|
38
|
-
|
39
|
-
def assert(test, msg="failed assertion (no message given)")
|
40
|
-
raise Test::Assertion, msg unless test
|
41
|
-
end
|
42
|
-
|
43
|
-
def assert_equal(exp, act, msg=nil)
|
44
|
-
assert exp == act, msg || "Expected #{act.inspect} to be equal to #{exp.inspect}"
|
45
|
-
end
|
46
|
-
|
47
|
-
def assert_in_delta(exp, act, delta, msg=nil)
|
48
|
-
assert((exp.to_f - act.to_f).abs <= delta.to_f, msg || "Expected #{exp} to be within #{delta} of #{act}")
|
49
|
-
end
|
50
|
-
|
51
|
-
def assert_instance_of(cls, obj, msg=nil)
|
52
|
-
assert cls === obj, msg || "Expected #{obj} to be a #{cls}"
|
53
|
-
end
|
54
|
-
|
55
|
-
def assert_kind_of(cls, obj, msg=nil)
|
56
|
-
assert obj.kind_of?(cls), msg || "Expected #{obj.inspect} to be a kind of #{cls}"
|
57
|
-
end
|
58
|
-
|
59
|
-
def assert_match(exp, act, msg=nil)
|
60
|
-
assert act =~ exp, msg || "Expected #{act.inspect} to match #{exp.inspect}"
|
61
|
-
end
|
62
|
-
|
63
|
-
def assert_nil(obj, msg=nil)
|
64
|
-
assert obj.nil?, msg || "Expected #{obj.inspect} to be nil"
|
65
|
-
end
|
66
|
-
|
67
|
-
def assert_not_equal(exp, act, msg=nil)
|
68
|
-
assert exp != act, msg || "Expected #{act.inspect} to not be equal to #{exp.inspect}"
|
69
|
-
end
|
70
|
-
|
71
|
-
def assert_not_nil(obj, msg=nil)
|
72
|
-
assert ! obj.nil?, msg || "Expected #{obj.inspect} to not be nil"
|
73
|
-
end
|
74
|
-
|
75
|
-
def assert_not_same(exp, act, msg=nil)
|
76
|
-
assert ! exp.equal?(act), msg || "Expected #{act.inspect} to not be the same as #{exp.inspect}"
|
77
|
-
end
|
78
|
-
|
79
|
-
def assert_raises(exp, msg=nil)
|
80
|
-
begin
|
81
|
-
yield
|
82
|
-
assert false, "Expected #{exp} to be raised"
|
83
|
-
rescue Exception => e
|
84
|
-
assert exp === e, msg || "Expected #{exp} to be raised, but got #{e.class}"
|
85
|
-
return e
|
86
|
-
end
|
87
|
-
end
|
88
|
-
alias :assert_raise :assert_raises
|
89
|
-
|
90
|
-
def assert_same(exp, act, msg=nil)
|
91
|
-
assert exp.equal?(act), msg || "Expected #{act.inspect} to be the same as #{exp.inspect}"
|
92
|
-
end
|
93
|
-
|
94
|
-
def assert_operator(o1, op, o2, msg="")
|
95
|
-
assert o1.__send__(op, o2), msg || "Expected #{o1}.#{op}(#{o2}) to be true"
|
96
|
-
end
|
97
|
-
|
98
|
-
def assert_nothing_raised; yield; end
|
99
|
-
|
100
|
-
end # class TestCase
|
101
|
-
end # class Unit
|
102
|
-
end # module Test
|
103
|
-
|
104
|
-
|
data/work/sandbox/unitspec.rb
DELETED
@@ -1,54 +0,0 @@
|
|
1
|
-
=begin
|
2
|
-
|
3
|
-
The idea here is that unit tests should reflect
|
4
|
-
the model of the class and method it is testing.
|
5
|
-
To do this we want to achieve a kind of AOP-like
|
6
|
-
system to monitor the original. So for instance,
|
7
|
-
given:
|
8
|
-
|
9
|
-
class Hash
|
10
|
-
|
11
|
-
# Push a pair onto the
|
12
|
-
#
|
13
|
-
#
|
14
|
-
def #<<(pair)
|
15
|
-
self.store(*pair)
|
16
|
-
end
|
17
|
-
|
18
|
-
end
|
19
|
-
|
20
|
-
We could construct:
|
21
|
-
|
22
|
-
require 'quarry/unitspec'
|
23
|
-
|
24
|
-
module Quarry::UnitSpecs
|
25
|
-
|
26
|
-
class Hash << ::Hash
|
27
|
-
|
28
|
-
def #<<(pair)
|
29
|
-
r = super
|
30
|
-
self[pair[0]].assert == pair[1]
|
31
|
-
r
|
32
|
-
end
|
33
|
-
|
34
|
-
end
|
35
|
-
|
36
|
-
h = Hash.new
|
37
|
-
h << [:a, 1]
|
38
|
-
|
39
|
-
end
|
40
|
-
|
41
|
-
To make this more convenient.
|
42
|
-
|
43
|
-
Quarry.unitspec(Hash) do
|
44
|
-
|
45
|
-
unit(:<<) do |pair|
|
46
|
-
r = super
|
47
|
-
self[pair[0]].assert == pair[1]
|
48
|
-
r
|
49
|
-
end
|
50
|
-
|
51
|
-
end
|
52
|
-
|
53
|
-
=end
|
54
|
-
|