From fcbf63e62c627deae76c1b8cb8c0876c536ed811 Mon Sep 17 00:00:00 2001 From: Jari Vetoniemi Date: Mon, 16 Mar 2020 18:49:26 +0900 Subject: Fresh start --- jni/ruby/test/json/test_json_fixtures.rb | 35 ++++++++++++++++++++++++++++++++ 1 file changed, 35 insertions(+) create mode 100755 jni/ruby/test/json/test_json_fixtures.rb (limited to 'jni/ruby/test/json/test_json_fixtures.rb') diff --git a/jni/ruby/test/json/test_json_fixtures.rb b/jni/ruby/test/json/test_json_fixtures.rb new file mode 100755 index 0000000..584dffd --- /dev/null +++ b/jni/ruby/test/json/test_json_fixtures.rb @@ -0,0 +1,35 @@ +#!/usr/bin/env ruby +# encoding: utf-8 + +require 'test/unit' +require File.join(File.dirname(__FILE__), 'setup_variant') + +class TestJSONFixtures < Test::Unit::TestCase + def setup + fixtures = File.join(File.dirname(__FILE__), 'fixtures/*.json') + passed, failed = Dir[fixtures].partition { |f| f['pass'] } + @passed = passed.inject([]) { |a, f| a << [ f, File.read(f) ] }.sort + @failed = failed.inject([]) { |a, f| a << [ f, File.read(f) ] }.sort + end + + def test_passing + for name, source in @passed + begin + assert JSON.parse(source), + "Did not pass for fixture '#{name}': #{source.inspect}" + rescue => e + warn "\nCaught #{e.class}(#{e}) for fixture '#{name}': #{source.inspect}\n#{e.backtrace * "\n"}" + raise e + end + end + end + + def test_failing + for name, source in @failed + assert_raises(JSON::ParserError, JSON::NestingError, + "Did not fail for fixture '#{name}': #{source.inspect}") do + JSON.parse(source) + end + end + end +end -- cgit v1.2.3