riess 0.0.8
Sign up to get free protection for your applications and to get access to all the features.
- data/examples/Getting_started_example.rb +17 -0
- data/lib/actions.rb +53 -0
- data/lib/checks.rb +39 -0
- data/lib/exceptions.rb +12 -0
- data/lib/finders.rb +129 -0
- data/lib/helpers.rb +115 -0
- data/lib/html_action_modules.rb +88 -0
- data/lib/html_check_modules.rb +161 -0
- data/lib/html_object_factory.rb +33 -0
- data/lib/html_objects.rb +57 -0
- data/lib/ieparser_extension.rb +416 -0
- data/lib/key_codes.rb +123 -0
- data/lib/popup.rb +57 -0
- data/lib/riess.rb +111 -0
- data/lib/test_reporter.rb +113 -0
- data/riess_stable_testing_release_1-0.0.8.gemspec +22 -0
- data/vendor/log4r-1.0.5/doc/contact.html +166 -0
- data/vendor/log4r-1.0.5/doc/contribute.html +165 -0
- data/vendor/log4r-1.0.5/doc/images/crush/logo2.png +0 -0
- data/vendor/log4r-1.0.5/doc/images/log4r-logo.png +0 -0
- data/vendor/log4r-1.0.5/doc/images/logo2.png +0 -0
- data/vendor/log4r-1.0.5/doc/index.html +228 -0
- data/vendor/log4r-1.0.5/doc/license.html +200 -0
- data/vendor/log4r-1.0.5/doc/log4r.css +111 -0
- data/vendor/log4r-1.0.5/doc/manual.html +593 -0
- data/vendor/log4r-1.0.5/doc/rdoc/blank.html +2 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r.html +105 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/BasicFormatter.html +133 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/BasicFormatter.src/M000073.html +18 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/BasicFormatter.src/M000074.html +22 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/BasicFormatter.src/M000075.html +25 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/ConfigError.html +60 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Configurator.html +151 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Configurator.src/M000003.html +16 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Configurator.src/M000004.html +16 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Configurator.src/M000005.html +25 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Configurator.src/M000006.html +19 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Configurator.src/M000007.html +19 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/DateFileOutputter.html +84 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/DateFileOutputter.src/M000010.html +33 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/DefaultFormatter.html +62 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/EmailOutputter.html +123 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/EmailOutputter.src/M000047.html +32 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/EmailOutputter.src/M000048.html +19 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/FileOutputter.html +99 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/FileOutputter.src/M000011.html +45 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Formatter.html +91 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Formatter.src/M000076.html +17 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Formatter.src/M000077.html +17 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/IOOutputter.html +112 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/IOOutputter.src/M000049.html +19 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/IOOutputter.src/M000050.html +18 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/IOOutputter.src/M000051.html +21 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Log4rTools.html +116 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Log4rTools.src/M000032.html +21 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Log4rTools.src/M000033.html +18 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Log4rTools.src/M000034.html +24 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Log4rTools.src/M000035.html +18 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/LogEvent.html +132 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/LogEvent.src/M000001.html +19 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/LogServer.html +103 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/LogServer.src/M000044.html +22 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/LogServer.src/M000045.html +18 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Logger.html +341 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Logger.src/M000052.html +16 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Logger.src/M000053.html +16 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Logger.src/M000054.html +20 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Logger.src/M000055.html +22 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Logger.src/M000056.html +20 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Logger.src/M000057.html +18 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Logger.src/M000058.html +20 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Logger.src/M000059.html +30 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Logger.src/M000060.html +22 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Logger.src/M000061.html +21 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Logger.src/M000062.html +24 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Logger.src/M000063.html +18 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Logger.src/M000064.html +19 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Logger.src/M000065.html +29 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Logger.src/M000066.html +22 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Logger.src/M000067.html +16 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Logger.src/M000068.html +18 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/ObjectFormatter.html +85 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/ObjectFormatter.src/M000009.html +21 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Outputter.html +229 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Outputter.src/M000015.html +25 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Outputter.src/M000016.html +16 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Outputter.src/M000017.html +16 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Outputter.src/M000018.html +18 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Outputter.src/M000019.html +18 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Outputter.src/M000020.html +18 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Outputter.src/M000021.html +23 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Outputter.src/M000022.html +21 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Outputter.src/M000023.html +26 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Outputter.src/M000024.html +29 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/Outputter.src/M000025.html +17 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/PatternFormatter.html +120 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/PatternFormatter.src/M000046.html +23 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/RemoteOutputter.html +104 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/RemoteOutputter.src/M000012.html +22 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/RemoteOutputter.src/M000013.html +18 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/RemoteOutputter.src/M000014.html +18 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/RollingFileOutputter.html +111 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/RollingFileOutputter.src/M000069.html +45 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/RootLogger.html +173 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/RootLogger.src/M000036.html +23 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/RootLogger.src/M000037.html +16 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/RootLogger.src/M000038.html +16 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/RootLogger.src/M000039.html +16 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/RootLogger.src/M000040.html +16 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/RootLogger.src/M000041.html +16 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/RootLogger.src/M000042.html +16 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/RootLogger.src/M000043.html +16 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/SimpleFormatter.html +83 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/SimpleFormatter.src/M000026.html +19 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/StderrOutputter.html +76 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/StderrOutputter.src/M000002.html +18 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/StdoutOutputter.html +76 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/StdoutOutputter.src/M000008.html +18 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/SyslogOutputter.html +111 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/SyslogOutputter.src/M000070.html +22 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/SyslogOutputter.src/M000071.html +18 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/SyslogOutputter.src/M000072.html +21 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/YamlConfigurator.html +128 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/YamlConfigurator.src/M000027.html +16 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/YamlConfigurator.src/M000028.html +16 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/YamlConfigurator.src/M000029.html +25 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/YamlConfigurator.src/M000030.html +18 -0
- data/vendor/log4r-1.0.5/doc/rdoc/classes/Log4r/YamlConfigurator.src/M000031.html +18 -0
- data/vendor/log4r-1.0.5/doc/rdoc/created.rid +1 -0
- data/vendor/log4r-1.0.5/doc/rdoc/files/log4r/configurator_rb.html +402 -0
- data/vendor/log4r-1.0.5/doc/rdoc/files/log4r/formatter/formatter_rb.html +152 -0
- data/vendor/log4r-1.0.5/doc/rdoc/files/log4r/formatter/patternformatter_rb.html +266 -0
- data/vendor/log4r-1.0.5/doc/rdoc/files/log4r/logger_rb.html +320 -0
- data/vendor/log4r-1.0.5/doc/rdoc/files/log4r/logserver_rb.html +191 -0
- data/vendor/log4r-1.0.5/doc/rdoc/files/log4r/outputter/datefileoutputter_rb.html +120 -0
- data/vendor/log4r-1.0.5/doc/rdoc/files/log4r/outputter/emailoutputter_rb.html +205 -0
- data/vendor/log4r-1.0.5/doc/rdoc/files/log4r/outputter/outputter_rb.html +254 -0
- data/vendor/log4r-1.0.5/doc/rdoc/files/log4r/outputter/syslogoutputter_rb.html +135 -0
- data/vendor/log4r-1.0.5/doc/rdoc/files/log4r/yamlconfigurator_rb.html +120 -0
- data/vendor/log4r-1.0.5/doc/rdoc/files/log4r_rb.html +228 -0
- data/vendor/log4r-1.0.5/doc/rdoc/fr_class_index.html +59 -0
- data/vendor/log4r-1.0.5/doc/rdoc/fr_file_index.html +45 -0
- data/vendor/log4r-1.0.5/doc/rdoc/fr_method_index.html +111 -0
- data/vendor/log4r-1.0.5/doc/rdoc/index.html +26 -0
- data/vendor/log4r-1.0.5/doc/rdoc/rdoc-style.css +79 -0
- data/vendor/log4r-1.0.5/examples/README +19 -0
- data/vendor/log4r-1.0.5/examples/customlevels.rb +34 -0
- data/vendor/log4r-1.0.5/examples/fileroll.rb +40 -0
- data/vendor/log4r-1.0.5/examples/log4r_yaml.yaml +0 -0
- data/vendor/log4r-1.0.5/examples/logclient.rb +25 -0
- data/vendor/log4r-1.0.5/examples/logserver.rb +18 -0
- data/vendor/log4r-1.0.5/examples/moderate.xml +29 -0
- data/vendor/log4r-1.0.5/examples/moderateconfig.rb +66 -0
- data/vendor/log4r-1.0.5/examples/myformatter.rb +23 -0
- data/vendor/log4r-1.0.5/examples/outofthebox.rb +21 -0
- data/vendor/log4r-1.0.5/examples/rrconfig.xml +63 -0
- data/vendor/log4r-1.0.5/examples/rrsetup.rb +42 -0
- data/vendor/log4r-1.0.5/examples/simpleconfig.rb +39 -0
- data/vendor/log4r-1.0.5/examples/xmlconfig.rb +25 -0
- data/vendor/log4r-1.0.5/examples/yaml.rb +30 -0
- data/vendor/log4r-1.0.5/src/log4r.rb +20 -0
- data/vendor/log4r-1.0.5/src/log4r/base.rb +74 -0
- data/vendor/log4r-1.0.5/src/log4r/config.rb +9 -0
- data/vendor/log4r-1.0.5/src/log4r/configurator.rb +224 -0
- data/vendor/log4r-1.0.5/src/log4r/formatter/formatter.rb +105 -0
- data/vendor/log4r-1.0.5/src/log4r/formatter/patternformatter.rb +108 -0
- data/vendor/log4r-1.0.5/src/log4r/lib/drbloader.rb +52 -0
- data/vendor/log4r-1.0.5/src/log4r/lib/xmlloader.rb +24 -0
- data/vendor/log4r-1.0.5/src/log4r/logevent.rb +28 -0
- data/vendor/log4r-1.0.5/src/log4r/logger.rb +194 -0
- data/vendor/log4r-1.0.5/src/log4r/loggerfactory.rb +89 -0
- data/vendor/log4r-1.0.5/src/log4r/logserver.rb +28 -0
- data/vendor/log4r-1.0.5/src/log4r/outputter/consoleoutputters.rb +18 -0
- data/vendor/log4r-1.0.5/src/log4r/outputter/datefileoutputter.rb +110 -0
- data/vendor/log4r-1.0.5/src/log4r/outputter/emailoutputter.rb +115 -0
- data/vendor/log4r-1.0.5/src/log4r/outputter/fileoutputter.rb +49 -0
- data/vendor/log4r-1.0.5/src/log4r/outputter/iooutputter.rb +55 -0
- data/vendor/log4r-1.0.5/src/log4r/outputter/outputter.rb +132 -0
- data/vendor/log4r-1.0.5/src/log4r/outputter/outputterfactory.rb +59 -0
- data/vendor/log4r-1.0.5/src/log4r/outputter/remoteoutputter.rb +40 -0
- data/vendor/log4r-1.0.5/src/log4r/outputter/rollingfileoutputter.rb +126 -0
- data/vendor/log4r-1.0.5/src/log4r/outputter/staticoutputter.rb +30 -0
- data/vendor/log4r-1.0.5/src/log4r/outputter/syslogoutputter.rb +75 -0
- data/vendor/log4r-1.0.5/src/log4r/rdoc/configurator +243 -0
- data/vendor/log4r-1.0.5/src/log4r/rdoc/emailoutputter +103 -0
- data/vendor/log4r-1.0.5/src/log4r/rdoc/formatter +39 -0
- data/vendor/log4r-1.0.5/src/log4r/rdoc/log4r +89 -0
- data/vendor/log4r-1.0.5/src/log4r/rdoc/logger +175 -0
- data/vendor/log4r-1.0.5/src/log4r/rdoc/logserver +85 -0
- data/vendor/log4r-1.0.5/src/log4r/rdoc/outputter +108 -0
- data/vendor/log4r-1.0.5/src/log4r/rdoc/patternformatter +128 -0
- data/vendor/log4r-1.0.5/src/log4r/rdoc/syslogoutputter +29 -0
- data/vendor/log4r-1.0.5/src/log4r/rdoc/yamlconfigurator +20 -0
- data/vendor/log4r-1.0.5/src/log4r/repository.rb +65 -0
- data/vendor/log4r-1.0.5/src/log4r/staticlogger.rb +49 -0
- data/vendor/log4r-1.0.5/src/log4r/yamlconfigurator.rb +0 -0
- data/vendor/log4r-1.0.5/tests/include.rb +7 -0
- data/vendor/log4r-1.0.5/tests/runtest.rb +6 -0
- data/vendor/log4r-1.0.5/tests/testbase.rb +45 -0
- data/vendor/log4r-1.0.5/tests/testcustom.rb +33 -0
- data/vendor/log4r-1.0.5/tests/testdefault.rb +25 -0
- data/vendor/log4r-1.0.5/tests/testformatter.rb +29 -0
- data/vendor/log4r-1.0.5/tests/testlogger.rb +198 -0
- data/vendor/log4r-1.0.5/tests/testoutputter.rb +112 -0
- data/vendor/log4r-1.0.5/tests/testpatternformatter.rb +26 -0
- data/vendor/log4r-1.0.5/tests/testxmlconf.rb +51 -0
- data/vendor/log4r-1.0.5/tests/xml/testconf.xml +37 -0
- data/vendor/rspec-0.8.2/CHANGES +575 -0
- data/vendor/rspec-0.8.2/EXAMPLES.rd +81 -0
- data/vendor/rspec-0.8.2/MIT-LICENSE +20 -0
- data/vendor/rspec-0.8.2/README +57 -0
- data/vendor/rspec-0.8.2/RELEASE-PLAN +117 -0
- data/vendor/rspec-0.8.2/Rakefile +223 -0
- data/vendor/rspec-0.8.2/bin/spec +4 -0
- data/vendor/rspec-0.8.2/examples/auto_spec_name_generation_example.rb +18 -0
- data/vendor/rspec-0.8.2/examples/custom_expectation_matchers.rb +53 -0
- data/vendor/rspec-0.8.2/examples/custom_formatter.rb +11 -0
- data/vendor/rspec-0.8.2/examples/dynamic_spec.rb +9 -0
- data/vendor/rspec-0.8.2/examples/file_accessor.rb +18 -0
- data/vendor/rspec-0.8.2/examples/file_accessor_spec.rb +38 -0
- data/vendor/rspec-0.8.2/examples/greeter_spec.rb +30 -0
- data/vendor/rspec-0.8.2/examples/helper_method_example.rb +11 -0
- data/vendor/rspec-0.8.2/examples/io_processor.rb +8 -0
- data/vendor/rspec-0.8.2/examples/io_processor_spec.rb +21 -0
- data/vendor/rspec-0.8.2/examples/mocking_example.rb +27 -0
- data/vendor/rspec-0.8.2/examples/partial_mock_example.rb +28 -0
- data/vendor/rspec-0.8.2/examples/predicate_example.rb +27 -0
- data/vendor/rspec-0.8.2/examples/setup_teardown_example.rb +34 -0
- data/vendor/rspec-0.8.2/examples/spec_helper.rb +1 -0
- data/vendor/rspec-0.8.2/examples/stack.rb +36 -0
- data/vendor/rspec-0.8.2/examples/stack_spec.rb +113 -0
- data/vendor/rspec-0.8.2/examples/stubbing_example.rb +69 -0
- data/vendor/rspec-0.8.2/examples/test_case_spec.rb +63 -0
- data/vendor/rspec-0.8.2/lib/spec.rb +11 -0
- data/vendor/rspec-0.8.2/lib/spec/callback.rb +11 -0
- data/vendor/rspec-0.8.2/lib/spec/callback/callback_container.rb +60 -0
- data/vendor/rspec-0.8.2/lib/spec/callback/extensions/module.rb +24 -0
- data/vendor/rspec-0.8.2/lib/spec/callback/extensions/object.rb +37 -0
- data/vendor/rspec-0.8.2/lib/spec/deprecated.rb +3 -0
- data/vendor/rspec-0.8.2/lib/spec/expectations.rb +59 -0
- data/vendor/rspec-0.8.2/lib/spec/expectations/differs/default.rb +62 -0
- data/vendor/rspec-0.8.2/lib/spec/expectations/errors.rb +6 -0
- data/vendor/rspec-0.8.2/lib/spec/expectations/extensions.rb +3 -0
- data/vendor/rspec-0.8.2/lib/spec/expectations/extensions/object.rb +109 -0
- data/vendor/rspec-0.8.2/lib/spec/expectations/extensions/proc.rb +57 -0
- data/vendor/rspec-0.8.2/lib/spec/expectations/extensions/string_and_symbol.rb +17 -0
- data/vendor/rspec-0.8.2/lib/spec/expectations/handler.rb +47 -0
- data/vendor/rspec-0.8.2/lib/spec/expectations/should.rb +5 -0
- data/vendor/rspec-0.8.2/lib/spec/expectations/should/base.rb +64 -0
- data/vendor/rspec-0.8.2/lib/spec/expectations/should/change.rb +69 -0
- data/vendor/rspec-0.8.2/lib/spec/expectations/should/have.rb +128 -0
- data/vendor/rspec-0.8.2/lib/spec/expectations/should/not.rb +74 -0
- data/vendor/rspec-0.8.2/lib/spec/expectations/should/should.rb +81 -0
- data/vendor/rspec-0.8.2/lib/spec/expectations/sugar.rb +47 -0
- data/vendor/rspec-0.8.2/lib/spec/matchers.rb +160 -0
- data/vendor/rspec-0.8.2/lib/spec/matchers/be.rb +161 -0
- data/vendor/rspec-0.8.2/lib/spec/matchers/be_close.rb +37 -0
- data/vendor/rspec-0.8.2/lib/spec/matchers/change.rb +120 -0
- data/vendor/rspec-0.8.2/lib/spec/matchers/eql.rb +43 -0
- data/vendor/rspec-0.8.2/lib/spec/matchers/equal.rb +43 -0
- data/vendor/rspec-0.8.2/lib/spec/matchers/has.rb +44 -0
- data/vendor/rspec-0.8.2/lib/spec/matchers/have.rb +140 -0
- data/vendor/rspec-0.8.2/lib/spec/matchers/include.rb +50 -0
- data/vendor/rspec-0.8.2/lib/spec/matchers/match.rb +41 -0
- data/vendor/rspec-0.8.2/lib/spec/matchers/raise_error.rb +100 -0
- data/vendor/rspec-0.8.2/lib/spec/matchers/respond_to.rb +35 -0
- data/vendor/rspec-0.8.2/lib/spec/matchers/satisfy.rb +47 -0
- data/vendor/rspec-0.8.2/lib/spec/matchers/throw_symbol.rb +75 -0
- data/vendor/rspec-0.8.2/lib/spec/mocks.rb +232 -0
- data/vendor/rspec-0.8.2/lib/spec/mocks/argument_expectation.rb +132 -0
- data/vendor/rspec-0.8.2/lib/spec/mocks/error_generator.rb +85 -0
- data/vendor/rspec-0.8.2/lib/spec/mocks/errors.rb +10 -0
- data/vendor/rspec-0.8.2/lib/spec/mocks/extensions/object.rb +3 -0
- data/vendor/rspec-0.8.2/lib/spec/mocks/message_expectation.rb +231 -0
- data/vendor/rspec-0.8.2/lib/spec/mocks/methods.rb +40 -0
- data/vendor/rspec-0.8.2/lib/spec/mocks/mock.rb +26 -0
- data/vendor/rspec-0.8.2/lib/spec/mocks/mock_handler.rb +166 -0
- data/vendor/rspec-0.8.2/lib/spec/mocks/order_group.rb +29 -0
- data/vendor/rspec-0.8.2/lib/spec/rake/spectask.rb +173 -0
- data/vendor/rspec-0.8.2/lib/spec/rake/verify_rcov.rb +47 -0
- data/vendor/rspec-0.8.2/lib/spec/runner.rb +132 -0
- data/vendor/rspec-0.8.2/lib/spec/runner/backtrace_tweaker.rb +55 -0
- data/vendor/rspec-0.8.2/lib/spec/runner/command_line.rb +34 -0
- data/vendor/rspec-0.8.2/lib/spec/runner/context.rb +154 -0
- data/vendor/rspec-0.8.2/lib/spec/runner/context_eval.rb +142 -0
- data/vendor/rspec-0.8.2/lib/spec/runner/context_runner.rb +55 -0
- data/vendor/rspec-0.8.2/lib/spec/runner/drb_command_line.rb +21 -0
- data/vendor/rspec-0.8.2/lib/spec/runner/execution_context.rb +17 -0
- data/vendor/rspec-0.8.2/lib/spec/runner/extensions/kernel.rb +17 -0
- data/vendor/rspec-0.8.2/lib/spec/runner/extensions/object.rb +32 -0
- data/vendor/rspec-0.8.2/lib/spec/runner/formatter.rb +5 -0
- data/vendor/rspec-0.8.2/lib/spec/runner/formatter/base_text_formatter.rb +118 -0
- data/vendor/rspec-0.8.2/lib/spec/runner/formatter/html_formatter.rb +219 -0
- data/vendor/rspec-0.8.2/lib/spec/runner/formatter/progress_bar_formatter.rb +27 -0
- data/vendor/rspec-0.8.2/lib/spec/runner/formatter/rdoc_formatter.rb +22 -0
- data/vendor/rspec-0.8.2/lib/spec/runner/formatter/specdoc_formatter.rb +23 -0
- data/vendor/rspec-0.8.2/lib/spec/runner/heckle_runner.rb +71 -0
- data/vendor/rspec-0.8.2/lib/spec/runner/heckle_runner_win.rb +10 -0
- data/vendor/rspec-0.8.2/lib/spec/runner/option_parser.rb +224 -0
- data/vendor/rspec-0.8.2/lib/spec/runner/reporter.rb +105 -0
- data/vendor/rspec-0.8.2/lib/spec/runner/spec_matcher.rb +25 -0
- data/vendor/rspec-0.8.2/lib/spec/runner/spec_parser.rb +41 -0
- data/vendor/rspec-0.8.2/lib/spec/runner/spec_should_raise_handler.rb +74 -0
- data/vendor/rspec-0.8.2/lib/spec/runner/specification.rb +114 -0
- data/vendor/rspec-0.8.2/lib/spec/translator.rb +87 -0
- data/vendor/rspec-0.8.2/lib/spec/version.rb +30 -0
- data/vendor/rspec-0.8.2/spec/spec/callback/callback_container_spec.rb +27 -0
- data/vendor/rspec-0.8.2/spec/spec/callback/module_spec.rb +37 -0
- data/vendor/rspec-0.8.2/spec/spec/callback/object_spec.rb +90 -0
- data/vendor/rspec-0.8.2/spec/spec/callback/object_with_class_callback_spec.rb +19 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/differs/default_spec.rb +107 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/extensions/object_spec.rb +46 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/fail_with_spec.rb +71 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/should/should_==_spec.rb +19 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/should/should_=~_spec.rb +13 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/should/should_be_a_kind_of_spec.rb +21 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/should/should_be_an_instance_of_spec.rb +30 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/should/should_be_arbitrary_predicate_spec.rb +81 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/should/should_be_close_spec.rb +18 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/should/should_be_comparison_operator_spec.rb +44 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/should/should_be_false_spec.rb +39 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/should/should_be_spec.rb +11 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/should/should_be_true_spec.rb +27 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/should/should_change_spec.rb +184 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/should/should_eql_spec.rb +11 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/should/should_equal_spec.rb +11 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/should/should_have_at_least_spec.rb +53 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/should/should_have_at_most_spec.rb +45 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/should/should_have_key_spec.rb +21 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/should/should_have_spec.rb +64 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/should/should_include_spec.rb +59 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/should/should_match_spec.rb +25 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/should/should_not_==_spec.rb +15 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/should/should_not_be_a_kind_of_spec.rb +21 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/should/should_not_be_an_instance_of_spec.rb +11 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/should/should_not_be_arbitrary_predicate_spec.rb +68 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/should/should_not_be_spec.rb +11 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/should/should_not_change_spec.rb +24 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/should/should_not_eql_spec.rb +11 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/should/should_not_equal_spec.rb +11 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/should/should_not_have_key_spec.rb +15 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/should/should_not_include_spec.rb +58 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/should/should_not_match_spec.rb +11 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/should/should_not_raise_spec.rb +75 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/should/should_not_respond_to_spec.rb +15 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/should/should_not_throw_spec.rb +35 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/should/should_raise_spec.rb +66 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/should/should_respond_to_spec.rb +15 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/should/should_satisfy_spec.rb +35 -0
- data/vendor/rspec-0.8.2/spec/spec/expectations/should/should_throw_spec.rb +27 -0
- data/vendor/rspec-0.8.2/spec/spec/matchers/be_close_spec.rb +33 -0
- data/vendor/rspec-0.8.2/spec/spec/matchers/be_spec.rb +182 -0
- data/vendor/rspec-0.8.2/spec/spec/matchers/change_spec.rb +232 -0
- data/vendor/rspec-0.8.2/spec/spec/matchers/description_generation_spec.rb +147 -0
- data/vendor/rspec-0.8.2/spec/spec/matchers/eql_spec.rb +41 -0
- data/vendor/rspec-0.8.2/spec/spec/matchers/equal_spec.rb +41 -0
- data/vendor/rspec-0.8.2/spec/spec/matchers/handler_spec.rb +75 -0
- data/vendor/rspec-0.8.2/spec/spec/matchers/has_spec.rb +37 -0
- data/vendor/rspec-0.8.2/spec/spec/matchers/have_spec.rb +259 -0
- data/vendor/rspec-0.8.2/spec/spec/matchers/include_spec.rb +33 -0
- data/vendor/rspec-0.8.2/spec/spec/matchers/match_spec.rb +37 -0
- data/vendor/rspec-0.8.2/spec/spec/matchers/matcher_methods_spec.rb +85 -0
- data/vendor/rspec-0.8.2/spec/spec/matchers/raise_error_spec.rb +147 -0
- data/vendor/rspec-0.8.2/spec/spec/matchers/respond_to_spec.rb +30 -0
- data/vendor/rspec-0.8.2/spec/spec/matchers/satisfy_spec.rb +36 -0
- data/vendor/rspec-0.8.2/spec/spec/matchers/throw_symbol_spec.rb +59 -0
- data/vendor/rspec-0.8.2/spec/spec/mocks/any_number_of_times_spec.rb +34 -0
- data/vendor/rspec-0.8.2/spec/spec/mocks/argument_expectation_spec.rb +19 -0
- data/vendor/rspec-0.8.2/spec/spec/mocks/at_least_spec.rb +97 -0
- data/vendor/rspec-0.8.2/spec/spec/mocks/at_most_spec.rb +97 -0
- data/vendor/rspec-0.8.2/spec/spec/mocks/bug_report_7611_spec.rb +19 -0
- data/vendor/rspec-0.8.2/spec/spec/mocks/bug_report_7805_spec.rb +22 -0
- data/vendor/rspec-0.8.2/spec/spec/mocks/bug_report_8165_spec.rb +31 -0
- data/vendor/rspec-0.8.2/spec/spec/mocks/bug_report_8302_spec.rb +26 -0
- data/vendor/rspec-0.8.2/spec/spec/mocks/failing_mock_argument_constraints_spec.rb +74 -0
- data/vendor/rspec-0.8.2/spec/spec/mocks/mock_ordering_spec.rb +80 -0
- data/vendor/rspec-0.8.2/spec/spec/mocks/mock_spec.rb +407 -0
- data/vendor/rspec-0.8.2/spec/spec/mocks/multiple_return_value_spec.rb +113 -0
- data/vendor/rspec-0.8.2/spec/spec/mocks/null_object_mock_spec.rb +40 -0
- data/vendor/rspec-0.8.2/spec/spec/mocks/once_counts_spec.rb +56 -0
- data/vendor/rspec-0.8.2/spec/spec/mocks/options_hash_spec.rb +31 -0
- data/vendor/rspec-0.8.2/spec/spec/mocks/partial_mock_spec.rb +52 -0
- data/vendor/rspec-0.8.2/spec/spec/mocks/partial_mock_using_mocks_directly_spec.rb +64 -0
- data/vendor/rspec-0.8.2/spec/spec/mocks/passing_mock_argument_constraints_spec.rb +92 -0
- data/vendor/rspec-0.8.2/spec/spec/mocks/precise_counts_spec.rb +56 -0
- data/vendor/rspec-0.8.2/spec/spec/mocks/record_messages_spec.rb +26 -0
- data/vendor/rspec-0.8.2/spec/spec/mocks/stub_spec.rb +159 -0
- data/vendor/rspec-0.8.2/spec/spec/mocks/twice_counts_spec.rb +67 -0
- data/vendor/rspec-0.8.2/spec/spec/runner/command_line_spec.rb +32 -0
- data/vendor/rspec-0.8.2/spec/spec/runner/context_matching_spec.rb +28 -0
- data/vendor/rspec-0.8.2/spec/spec/runner/context_runner_spec.rb +100 -0
- data/vendor/rspec-0.8.2/spec/spec/runner/context_spec.rb +405 -0
- data/vendor/rspec-0.8.2/spec/spec/runner/drb_command_line_spec.rb +74 -0
- data/vendor/rspec-0.8.2/spec/spec/runner/execution_context_spec.rb +52 -0
- data/vendor/rspec-0.8.2/spec/spec/runner/formatter/html_formatter_spec.rb +40 -0
- data/vendor/rspec-0.8.2/spec/spec/runner/formatter/progress_bar_formatter_dry_run_spec.rb +21 -0
- data/vendor/rspec-0.8.2/spec/spec/runner/formatter/progress_bar_formatter_failure_dump_spec.rb +36 -0
- data/vendor/rspec-0.8.2/spec/spec/runner/formatter/progress_bar_formatter_spec.rb +78 -0
- data/vendor/rspec-0.8.2/spec/spec/runner/formatter/rdoc_formatter_dry_run_spec.rb +18 -0
- data/vendor/rspec-0.8.2/spec/spec/runner/formatter/rdoc_formatter_spec.rb +41 -0
- data/vendor/rspec-0.8.2/spec/spec/runner/formatter/specdoc_formatter_dry_run_spec.rb +21 -0
- data/vendor/rspec-0.8.2/spec/spec/runner/formatter/specdoc_formatter_spec.rb +46 -0
- data/vendor/rspec-0.8.2/spec/spec/runner/heckle_runner_spec.rb +63 -0
- data/vendor/rspec-0.8.2/spec/spec/runner/heckler_spec.rb +14 -0
- data/vendor/rspec-0.8.2/spec/spec/runner/kernel_ext_spec.rb +16 -0
- data/vendor/rspec-0.8.2/spec/spec/runner/noisy_backtrace_tweaker_spec.rb +45 -0
- data/vendor/rspec-0.8.2/spec/spec/runner/object_ext_spec.rb +11 -0
- data/vendor/rspec-0.8.2/spec/spec/runner/option_parser_spec.rb +269 -0
- data/vendor/rspec-0.8.2/spec/spec/runner/quiet_backtrace_tweaker_spec.rb +47 -0
- data/vendor/rspec-0.8.2/spec/spec/runner/reporter_spec.rb +126 -0
- data/vendor/rspec-0.8.2/spec/spec/runner/spec_matcher_spec.rb +107 -0
- data/vendor/rspec-0.8.2/spec/spec/runner/spec_name_generation_spec.rb +102 -0
- data/vendor/rspec-0.8.2/spec/spec/runner/spec_parser_spec.rb +37 -0
- data/vendor/rspec-0.8.2/spec/spec/runner/specification_class_spec.rb +72 -0
- data/vendor/rspec-0.8.2/spec/spec/runner/specification_instance_spec.rb +160 -0
- data/vendor/rspec-0.8.2/spec/spec/runner/specification_should_raise_spec.rb +136 -0
- data/vendor/rspec-0.8.2/spec/spec/spec_classes.rb +102 -0
- data/vendor/rspec-0.8.2/spec/spec/translator_spec.rb +79 -0
- data/vendor/rspec-0.8.2/spec/spec_helper.rb +35 -0
- metadata +537 -0
@@ -0,0 +1,25 @@
|
|
1
|
+
module Spec
|
2
|
+
module Runner
|
3
|
+
class SpecMatcher
|
4
|
+
|
5
|
+
attr_writer :spec_desc
|
6
|
+
def initialize(context_desc, spec_desc=nil)
|
7
|
+
@context_desc = context_desc
|
8
|
+
@spec_desc = spec_desc
|
9
|
+
end
|
10
|
+
|
11
|
+
def matches?(desc)
|
12
|
+
desc =~ /(^#{context_regexp} #{spec_regexp}$|^#{context_regexp}$|^#{spec_regexp}$)/
|
13
|
+
end
|
14
|
+
|
15
|
+
private
|
16
|
+
def context_regexp
|
17
|
+
Regexp.escape(@context_desc)
|
18
|
+
end
|
19
|
+
|
20
|
+
def spec_regexp
|
21
|
+
Regexp.escape(@spec_desc)
|
22
|
+
end
|
23
|
+
end
|
24
|
+
end
|
25
|
+
end
|
@@ -0,0 +1,41 @@
|
|
1
|
+
module Spec
|
2
|
+
module Runner
|
3
|
+
# Parses a spec file and finds the nearest spec for a given line number.
|
4
|
+
class SpecParser
|
5
|
+
def spec_name_for(io, line_number)
|
6
|
+
source = io.read
|
7
|
+
context = context_at_line(source, line_number)
|
8
|
+
spec = spec_at_line(source, line_number)
|
9
|
+
if context && spec
|
10
|
+
"#{context} #{spec}"
|
11
|
+
elsif context
|
12
|
+
context
|
13
|
+
else
|
14
|
+
nil
|
15
|
+
end
|
16
|
+
end
|
17
|
+
|
18
|
+
protected
|
19
|
+
|
20
|
+
def context_at_line(source, line_number)
|
21
|
+
find_above(source, line_number, /^\s*context\s+['|"](.*)['|"]/)
|
22
|
+
end
|
23
|
+
|
24
|
+
def spec_at_line(source, line_number)
|
25
|
+
find_above(source, line_number, /^\s*specify\s+['|"](.*)['|"]/)
|
26
|
+
end
|
27
|
+
|
28
|
+
def find_above(source, line_number, pattern)
|
29
|
+
lines_above_reversed(source, line_number).each do |line|
|
30
|
+
return $1 if line =~ pattern
|
31
|
+
end
|
32
|
+
nil
|
33
|
+
end
|
34
|
+
|
35
|
+
def lines_above_reversed(source, line_number)
|
36
|
+
lines = source.split("\n")
|
37
|
+
lines[0...line_number].reverse
|
38
|
+
end
|
39
|
+
end
|
40
|
+
end
|
41
|
+
end
|
@@ -0,0 +1,74 @@
|
|
1
|
+
module Spec
|
2
|
+
module Runner
|
3
|
+
class SpecShouldRaiseHandler
|
4
|
+
def initialize(file_and_line_number, opts)
|
5
|
+
@file_and_line_number = file_and_line_number
|
6
|
+
@options = opts
|
7
|
+
@expected_error_class = determine_error_class(opts)
|
8
|
+
@expected_error_message = determine_error_message(opts)
|
9
|
+
end
|
10
|
+
|
11
|
+
def determine_error_class(opts)
|
12
|
+
if candidate = opts[:should_raise]
|
13
|
+
if candidate.is_a?(Class)
|
14
|
+
return candidate
|
15
|
+
elsif candidate.is_a?(Array)
|
16
|
+
return candidate[0]
|
17
|
+
else
|
18
|
+
return Exception
|
19
|
+
end
|
20
|
+
end
|
21
|
+
end
|
22
|
+
|
23
|
+
def determine_error_message(opts)
|
24
|
+
if candidate = opts[:should_raise]
|
25
|
+
if candidate.is_a?(Array)
|
26
|
+
return candidate[1]
|
27
|
+
end
|
28
|
+
end
|
29
|
+
return nil
|
30
|
+
end
|
31
|
+
|
32
|
+
def build_message(exception=nil)
|
33
|
+
if @expected_error_message.nil?
|
34
|
+
message = "specify block expected #{@expected_error_class.to_s}"
|
35
|
+
else
|
36
|
+
message = "specify block expected #{@expected_error_class.new(@expected_error_message.to_s).inspect}"
|
37
|
+
end
|
38
|
+
message << " but raised #{exception.inspect}" if exception
|
39
|
+
message << " but nothing was raised" unless exception
|
40
|
+
message << "\n"
|
41
|
+
message << @file_and_line_number
|
42
|
+
end
|
43
|
+
|
44
|
+
def error_matches?(error)
|
45
|
+
return false unless error.kind_of?(@expected_error_class)
|
46
|
+
unless @expected_error_message.nil?
|
47
|
+
if @expected_error_message.is_a?(Regexp)
|
48
|
+
return false unless error.message =~ @expected_error_message
|
49
|
+
else
|
50
|
+
return false unless error.message == @expected_error_message
|
51
|
+
end
|
52
|
+
end
|
53
|
+
return true
|
54
|
+
end
|
55
|
+
|
56
|
+
def handle(errors)
|
57
|
+
if @expected_error_class
|
58
|
+
if errors.empty?
|
59
|
+
errors << Spec::Expectations::ExpectationNotMetError.new(build_message)
|
60
|
+
else
|
61
|
+
error_to_remove = errors.detect do |error|
|
62
|
+
error_matches?(error)
|
63
|
+
end
|
64
|
+
if error_to_remove.nil?
|
65
|
+
errors.insert(0,Spec::Expectations::ExpectationNotMetError.new(build_message(errors[0])))
|
66
|
+
else
|
67
|
+
errors.delete(error_to_remove)
|
68
|
+
end
|
69
|
+
end
|
70
|
+
end
|
71
|
+
end
|
72
|
+
end
|
73
|
+
end
|
74
|
+
end
|
@@ -0,0 +1,114 @@
|
|
1
|
+
module Spec
|
2
|
+
module Runner
|
3
|
+
class Specification
|
4
|
+
|
5
|
+
class << self
|
6
|
+
attr_accessor :current, :generated_description
|
7
|
+
protected :current=
|
8
|
+
|
9
|
+
callback_events :before_setup, :after_teardown
|
10
|
+
end
|
11
|
+
|
12
|
+
attr_reader :spec_block
|
13
|
+
callback_events :before_setup, :after_teardown
|
14
|
+
|
15
|
+
def initialize(name, opts={}, &spec_block)
|
16
|
+
@from = caller(0)[3]
|
17
|
+
@description = name
|
18
|
+
@options = opts
|
19
|
+
@spec_block = spec_block
|
20
|
+
@description_generated_callback = lambda { |desc| @generated_description = desc }
|
21
|
+
end
|
22
|
+
|
23
|
+
def run(reporter, setup_block, teardown_block, dry_run, execution_context)
|
24
|
+
reporter.spec_started(name) if reporter
|
25
|
+
return reporter.spec_finished(name) if dry_run
|
26
|
+
|
27
|
+
errors = []
|
28
|
+
begin
|
29
|
+
set_current
|
30
|
+
setup_ok = setup_spec(execution_context, errors, &setup_block)
|
31
|
+
spec_ok = execute_spec(execution_context, errors) if setup_ok
|
32
|
+
teardown_ok = teardown_spec(execution_context, errors, &teardown_block)
|
33
|
+
ensure
|
34
|
+
clear_current
|
35
|
+
end
|
36
|
+
|
37
|
+
SpecShouldRaiseHandler.new(@from, @options).handle(errors)
|
38
|
+
reporter.spec_finished(name, errors.first, failure_location(setup_ok, spec_ok, teardown_ok)) if reporter
|
39
|
+
end
|
40
|
+
|
41
|
+
def matches?(matcher, description)
|
42
|
+
matcher.spec_desc = name
|
43
|
+
matcher.matches?(description)
|
44
|
+
end
|
45
|
+
|
46
|
+
private
|
47
|
+
def name
|
48
|
+
@description == :__generate_description ? generated_description : @description
|
49
|
+
end
|
50
|
+
|
51
|
+
def generated_description
|
52
|
+
@generated_description || "NAME NOT GENERATED"
|
53
|
+
end
|
54
|
+
|
55
|
+
def setup_spec(execution_context, errors, &setup_block)
|
56
|
+
notify_before_setup(errors)
|
57
|
+
execution_context.instance_eval(&setup_block) if setup_block
|
58
|
+
return errors.empty?
|
59
|
+
rescue => e
|
60
|
+
errors << e
|
61
|
+
return false
|
62
|
+
end
|
63
|
+
|
64
|
+
def execute_spec(execution_context, errors)
|
65
|
+
begin
|
66
|
+
execution_context.instance_eval(&spec_block)
|
67
|
+
return true
|
68
|
+
rescue Exception => e
|
69
|
+
errors << e
|
70
|
+
return false
|
71
|
+
end
|
72
|
+
end
|
73
|
+
|
74
|
+
def teardown_spec(execution_context, errors, &teardown_block)
|
75
|
+
execution_context.instance_eval(&teardown_block) if teardown_block
|
76
|
+
notify_after_teardown(errors)
|
77
|
+
return errors.empty?
|
78
|
+
rescue => e
|
79
|
+
errors << e
|
80
|
+
return false
|
81
|
+
end
|
82
|
+
|
83
|
+
def notify_before_setup(errors)
|
84
|
+
notify_class_callbacks(:before_setup, self, &append_errors(errors))
|
85
|
+
notify_callbacks(:before_setup, self, &append_errors(errors))
|
86
|
+
end
|
87
|
+
|
88
|
+
def notify_after_teardown(errors)
|
89
|
+
notify_callbacks(:after_teardown, self, &append_errors(errors))
|
90
|
+
notify_class_callbacks(:after_teardown, self, &append_errors(errors))
|
91
|
+
end
|
92
|
+
|
93
|
+
def append_errors(errors)
|
94
|
+
proc {|error| errors << error}
|
95
|
+
end
|
96
|
+
|
97
|
+
def set_current
|
98
|
+
Spec::Matchers.description_generated(&@description_generated_callback)
|
99
|
+
self.class.send(:current=, self)
|
100
|
+
end
|
101
|
+
|
102
|
+
def clear_current
|
103
|
+
Spec::Matchers.unregister_callback(:description_generated, @description_generated_callback)
|
104
|
+
self.class.send(:current=, nil)
|
105
|
+
end
|
106
|
+
|
107
|
+
def failure_location(setup_ok, spec_ok, teardown_ok)
|
108
|
+
return 'setup' unless setup_ok
|
109
|
+
return name unless spec_ok
|
110
|
+
return 'teardown' unless teardown_ok
|
111
|
+
end
|
112
|
+
end
|
113
|
+
end
|
114
|
+
end
|
@@ -0,0 +1,87 @@
|
|
1
|
+
require 'fileutils'
|
2
|
+
|
3
|
+
module Spec
|
4
|
+
class Translator
|
5
|
+
def translate_dir(from, to)
|
6
|
+
from = File.expand_path(from)
|
7
|
+
to = File.expand_path(to)
|
8
|
+
if File.directory?(from)
|
9
|
+
FileUtils.mkdir_p(to) unless File.directory?(to)
|
10
|
+
Dir["#{from}/*"].each do |sub_from|
|
11
|
+
path = sub_from[from.length+1..-1]
|
12
|
+
sub_to = File.join(to, path)
|
13
|
+
translate_dir(sub_from, sub_to)
|
14
|
+
end
|
15
|
+
else
|
16
|
+
translate_file(from, to)
|
17
|
+
end
|
18
|
+
end
|
19
|
+
|
20
|
+
def translate_file(from, to)
|
21
|
+
translation = ""
|
22
|
+
File.open(from) do |io|
|
23
|
+
io.each_line do |line|
|
24
|
+
translation << translate(line)
|
25
|
+
end
|
26
|
+
end
|
27
|
+
File.open(to, "w") do |io|
|
28
|
+
io.write(translation)
|
29
|
+
end
|
30
|
+
end
|
31
|
+
|
32
|
+
def translate(line)
|
33
|
+
return line if line =~ /(should_not|should)_receive/
|
34
|
+
|
35
|
+
if line =~ /(.*\.)(should_not|should)(?:_be)(?!_)(.*)/m
|
36
|
+
pre = $1
|
37
|
+
should = $2
|
38
|
+
post = $3
|
39
|
+
be_or_equal = post =~ /(<|>)/ ? "be" : "equal"
|
40
|
+
|
41
|
+
return "#{pre}#{should} #{be_or_equal}#{post}"
|
42
|
+
end
|
43
|
+
|
44
|
+
if line =~ /(.*\.)(should_not|should)_(?!not)(.*)/m
|
45
|
+
pre = $1
|
46
|
+
should = $2
|
47
|
+
post = $3
|
48
|
+
|
49
|
+
post.gsub!(/^raise/, 'raise_error')
|
50
|
+
post.gsub!(/^throw/, 'throw_symbol')
|
51
|
+
|
52
|
+
unless standard_matcher?(post)
|
53
|
+
post = "be_#{post}"
|
54
|
+
end
|
55
|
+
|
56
|
+
line = "#{pre}#{should} #{post}"
|
57
|
+
end
|
58
|
+
|
59
|
+
line
|
60
|
+
end
|
61
|
+
|
62
|
+
def standard_matcher?(matcher)
|
63
|
+
patterns = [
|
64
|
+
/^be/,
|
65
|
+
/^be_close/,
|
66
|
+
/^eql/,
|
67
|
+
/^equal/,
|
68
|
+
/^has/,
|
69
|
+
/^have/,
|
70
|
+
/^change/,
|
71
|
+
/^include/,
|
72
|
+
/^match/,
|
73
|
+
/^raise_error/,
|
74
|
+
/^respond_to/,
|
75
|
+
/^satisfy/,
|
76
|
+
/^throw_symbol/,
|
77
|
+
# Extra ones that we use in spec_helper
|
78
|
+
/^pass/,
|
79
|
+
/^fail/,
|
80
|
+
/^fail_with/,
|
81
|
+
]
|
82
|
+
matched = patterns.detect{ |p| matcher =~ p }
|
83
|
+
!matched.nil?
|
84
|
+
end
|
85
|
+
|
86
|
+
end
|
87
|
+
end
|
@@ -0,0 +1,30 @@
|
|
1
|
+
module Spec
|
2
|
+
module VERSION
|
3
|
+
def self.build_tag
|
4
|
+
tag = "REL_" + [MAJOR, MINOR, TINY].join('_')
|
5
|
+
if defined?(RELEASE_CANDIDATE)
|
6
|
+
tag << "_" << RELEASE_CANDIDATE
|
7
|
+
end
|
8
|
+
tag
|
9
|
+
end
|
10
|
+
|
11
|
+
unless defined? MAJOR
|
12
|
+
MAJOR = 0
|
13
|
+
MINOR = 8
|
14
|
+
TINY = 2
|
15
|
+
# RELEASE_CANDIDATE = "RC1"
|
16
|
+
|
17
|
+
# RANDOM_TOKEN: 0.375509844656552
|
18
|
+
REV = "$LastChangedRevision: 1560 $".match(/LastChangedRevision: (\d+)/)[1]
|
19
|
+
|
20
|
+
STRING = [MAJOR, MINOR, TINY].join('.')
|
21
|
+
FULL_VERSION = "#{STRING} (r#{REV})"
|
22
|
+
TAG = build_tag
|
23
|
+
|
24
|
+
NAME = "RSpec"
|
25
|
+
URL = "http://rspec.rubyforge.org/"
|
26
|
+
|
27
|
+
DESCRIPTION = "#{NAME}-#{FULL_VERSION} - BDD for Ruby\n#{URL}"
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
@@ -0,0 +1,27 @@
|
|
1
|
+
require File.dirname(__FILE__) + '/../../spec_helper.rb'
|
2
|
+
|
3
|
+
context "A CallbackContainer instance" do
|
4
|
+
setup do
|
5
|
+
@container = Callback::CallbackContainer.new
|
6
|
+
end
|
7
|
+
|
8
|
+
specify "should define and call callbacks" do
|
9
|
+
@container.define(:foo) {:bar}
|
10
|
+
@container.define(:foo) {:baz}
|
11
|
+
@container.notify(:foo).should == [:bar, :baz]
|
12
|
+
end
|
13
|
+
|
14
|
+
specify "should undefine callbacks" do
|
15
|
+
callback_to_undefine = @container.define(:foo) {:bar}
|
16
|
+
@container.define(:foo) {:baz}
|
17
|
+
@container.undefine(:foo, callback_to_undefine)
|
18
|
+
@container.notify(:foo).should == [:baz]
|
19
|
+
end
|
20
|
+
|
21
|
+
specify "should clear all callbacks" do
|
22
|
+
@container.define(:foo) {:bar}
|
23
|
+
@container.define(:baz) {1}
|
24
|
+
@container.clear
|
25
|
+
@container.notify(:foo).should == []
|
26
|
+
end
|
27
|
+
end
|
@@ -0,0 +1,37 @@
|
|
1
|
+
require File.dirname(__FILE__) + '/../../spec_helper.rb'
|
2
|
+
|
3
|
+
context "A Module" do
|
4
|
+
specify "should provide callback_events and notify_callbacks methods" do
|
5
|
+
the_class = Class.new do
|
6
|
+
callback_events :foo
|
7
|
+
end
|
8
|
+
|
9
|
+
the_obj = the_class.new
|
10
|
+
the_obj.foo { :bar }
|
11
|
+
the_obj.notify_callbacks(:foo).should == [:bar]
|
12
|
+
end
|
13
|
+
|
14
|
+
specify "should support defining multiple callback_events with one call to callback_events" do
|
15
|
+
the_class = Class.new do
|
16
|
+
callback_events :foo, :bar
|
17
|
+
end
|
18
|
+
|
19
|
+
the_obj = the_class.new
|
20
|
+
the_obj.foo { 1 }
|
21
|
+
the_obj.bar { 2 }
|
22
|
+
the_obj.notify_callbacks(:foo).should == [1]
|
23
|
+
the_obj.notify_callbacks(:bar).should == [2]
|
24
|
+
end
|
25
|
+
|
26
|
+
specify "should provide unregister_callback method" do
|
27
|
+
the_class = Class.new do
|
28
|
+
callback_events :foo
|
29
|
+
end
|
30
|
+
|
31
|
+
the_obj = the_class.new
|
32
|
+
bar_proc = proc {:bar}
|
33
|
+
the_obj.foo &bar_proc
|
34
|
+
the_obj.unregister_callback(:foo, bar_proc)
|
35
|
+
the_obj.notify_callbacks(:foo).should == []
|
36
|
+
end
|
37
|
+
end
|
@@ -0,0 +1,90 @@
|
|
1
|
+
require File.dirname(__FILE__) + '/../../spec_helper.rb'
|
2
|
+
|
3
|
+
context "An Object" do
|
4
|
+
setup do
|
5
|
+
@callback_object = Object.new
|
6
|
+
end
|
7
|
+
|
8
|
+
specify "should be defined as a block and notified" do
|
9
|
+
specify_registration_and_notification do |callback_key, expected_callback|
|
10
|
+
@callback_object.register_callback(callback_key, &expected_callback)
|
11
|
+
end
|
12
|
+
end
|
13
|
+
|
14
|
+
specify "should be defined as a proc and notified" do
|
15
|
+
specify_registration_and_notification do |callback_key, expected_callback|
|
16
|
+
@callback_object.register_callback(callback_key, expected_callback)
|
17
|
+
end
|
18
|
+
end
|
19
|
+
|
20
|
+
specify "define should require callback with the call method" do
|
21
|
+
proc do
|
22
|
+
specify_registration_and_notification do |callback_key, expected_callback|
|
23
|
+
@callback_object.register_callback(callback_key)
|
24
|
+
end
|
25
|
+
end.should_raise(RuntimeError, "You must define the callback that accepts the call method.")
|
26
|
+
end
|
27
|
+
|
28
|
+
specify "should undefine a proc" do
|
29
|
+
specify_unregistration do |callback_key, callback|
|
30
|
+
@callback_object.unregister_callback callback_key, callback
|
31
|
+
end
|
32
|
+
end
|
33
|
+
|
34
|
+
specify "undefine should require callback with the call method" do
|
35
|
+
proc do
|
36
|
+
specify_unregistration do |callback_key, expected_callback|
|
37
|
+
@callback_object.unregister_callback(callback_key, nil)
|
38
|
+
end
|
39
|
+
end.should_raise(RuntimeError, "You may only undefine callbacks that use the call method.")
|
40
|
+
end
|
41
|
+
|
42
|
+
specify "should handle errors" do
|
43
|
+
@callback_object.register_callback(:error_callback) do
|
44
|
+
raise "First Error"
|
45
|
+
end
|
46
|
+
|
47
|
+
@callback_object.register_callback(:error_callback) do
|
48
|
+
raise "Second Error"
|
49
|
+
end
|
50
|
+
|
51
|
+
error_messages = []
|
52
|
+
@callback_object.notify_callbacks(:error_callback) do |e|
|
53
|
+
error_messages << e.message
|
54
|
+
end
|
55
|
+
|
56
|
+
error_messages.should_eql ["First Error", "Second Error"]
|
57
|
+
end
|
58
|
+
|
59
|
+
specify "should not fail with nothing to notify" do
|
60
|
+
@callback_object.notify_callbacks(:foobar, :argument)
|
61
|
+
end
|
62
|
+
|
63
|
+
protected
|
64
|
+
def specify_registration_and_notification
|
65
|
+
callback_key = :create
|
66
|
+
passed_callback_argument = nil
|
67
|
+
expected_callback = proc do |callback_argument|
|
68
|
+
passed_callback_argument = callback_argument
|
69
|
+
end
|
70
|
+
|
71
|
+
returned_callback = yield(callback_key, expected_callback)
|
72
|
+
returned_callback.should_equal expected_callback
|
73
|
+
|
74
|
+
expected_argument = Object.new
|
75
|
+
@callback_object.notify_callbacks(callback_key, expected_argument)
|
76
|
+
passed_callback_argument.should_equal expected_argument
|
77
|
+
end
|
78
|
+
|
79
|
+
def specify_unregistration
|
80
|
+
callback_key = :create
|
81
|
+
callback_called = false
|
82
|
+
callback = @callback_object.register_callback(callback_key) do
|
83
|
+
callback_called = true
|
84
|
+
end
|
85
|
+
|
86
|
+
yield(callback_key, callback)
|
87
|
+
@callback_object.notify_callbacks(callback_key)
|
88
|
+
callback_called.should_equal false
|
89
|
+
end
|
90
|
+
end
|