Sha256: 444a70b548210a7c1993f70a3483194ea1f6e7732bbf011e3dbcbd0c268a540b
Contents?: true
Size: 1.51 KB
Versions: 2
Compression:
Stored size: 1.51 KB
Contents
# # ActiveFacts tests: Parse all CQL files and check the generated Ruby. # Copyright (c) 2008 Clifford Heath. Read the LICENSE file. # require 'spec/spec_helper' require 'stringio' require 'activefacts/vocabulary' require 'activefacts/support' require 'activefacts/persistence' require 'activefacts/input/orm' require 'activefacts/generate/sql/server' include ActiveFacts include ActiveFacts::Metamodel describe "NORMA Loader with SQL output" do # Generate and return the SQL for the given vocabulary def sql(vocabulary) output = StringIO.new @dumper = ActiveFacts::Generate::SQL::SERVER.new(vocabulary.constellation, "norma") @dumper.generate(output) output.rewind output.read end pattern = ENV["AFTESTS"] || "*" Dir["examples/norma/#{pattern}.orm"].each do |orm_file| expected_file = orm_file.sub(%r{examples/norma/(.*).orm\Z}, 'examples/SQL/\1.sql') actual_file = orm_file.sub(%r{examples/norma/(.*).orm\Z}, 'spec/actual/\1.sql') it "should load #{orm_file} and dump SQL matching #{expected_file}" do vocabulary = ActiveFacts::Input::ORM.readfile(orm_file) # Build and save the actual file: sql_text = sql(vocabulary) File.open(actual_file, "w") { |f| f.write sql_text } pending("expected output file #{expected_file} not found") unless File.exists? expected_file expected_text = File.open(expected_file) {|f| f.read } sql_text.should_not differ_from(expected_text) File.delete(actual_file) # It succeeded, we don't need the file. end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
activefacts-0.8.6 | spec/norma_sql_spec.rb |
activefacts-0.8.5 | spec/norma_sql_spec.rb |