summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorZachary Scott <[email protected]>2015-09-02 23:11:18 -0400
committerZachary Scott <[email protected]>2015-09-03 01:02:53 -0400
commitbacb8268682e8d931a00e7894ed7904bc789d8c4 (patch)
tree9b34d3025d195741cc5c028fad9dd7962beec04a
parentcc0b28373a304541308b6386f4be15aedf30ce43 (diff)
downloadmruby-bacb8268682e8d931a00e7894ed7904bc789d8c4.tar.gz
mruby-bacb8268682e8d931a00e7894ed7904bc789d8c4.zip
Add build_mrbtest after config block is evaluated
This allows us to add `enable_test` anywhere in a build target, without having to worry about the order in which they are included. Previously, there was a bug that occured when adding 'mruby-test' gem to dependencies before additional gems. Instead of adding the 'mruby-test' gem dependency manually to a test build, we now only need to call `enable_test` in the target. This also allows us to call `test_enabled?` downstream when running mruby tests ourselves. /cc #2924
-rw-r--r--Rakefile4
-rw-r--r--build_config.rb2
-rw-r--r--mrbgems/mruby-test/mrbgem.rake2
-rw-r--r--tasks/mruby_build.rake21
-rw-r--r--travis_config.rb12
5 files changed, 23 insertions, 18 deletions
diff --git a/Rakefile b/Rakefile
index 574c1365a..8a8912af5 100644
--- a/Rakefile
+++ b/Rakefile
@@ -116,9 +116,7 @@ end
desc "run all mruby tests"
task :test => ["all"] do
MRuby.each_target do
- if gems.find { |v| v.name == 'mruby-test' }
- run_test unless build_mrbtest_lib_only?
- end
+ run_test if test_enabled?
end
end
diff --git a/build_config.rb b/build_config.rb
index 34b92637c..d3c1ebc1f 100644
--- a/build_config.rb
+++ b/build_config.rb
@@ -114,9 +114,9 @@ MRuby::Build.new('test') do |conf|
enable_debug
conf.enable_bintest
+ conf.enable_test
conf.gembox 'default'
- conf.gem :core => "mruby-test"
end
# Define cross build settings
diff --git a/mrbgems/mruby-test/mrbgem.rake b/mrbgems/mruby-test/mrbgem.rake
index 8370f4713..b6b247ff6 100644
--- a/mrbgems/mruby-test/mrbgem.rake
+++ b/mrbgems/mruby-test/mrbgem.rake
@@ -32,7 +32,7 @@ MRuby::Gem::Specification.new('mruby-test') do |spec|
end
end
- gem_table = build.gems.generate_gem_table self
+ gem_table = build.gems.generate_gem_table build
build.gems.each do |g|
test_rbobj = g.test_rbireps.ext(exts.object)
diff --git a/tasks/mruby_build.rake b/tasks/mruby_build.rake
index b3a5dcdad..6863b635a 100644
--- a/tasks/mruby_build.rake
+++ b/tasks/mruby_build.rake
@@ -46,7 +46,7 @@ module MRuby
include LoadGems
attr_accessor :name, :bins, :exts, :file_separator, :build_dir, :gem_clone_dir
attr_reader :libmruby, :gems, :toolchains
- attr_writer :enable_bintest
+ attr_writer :enable_bintest, :enable_test
COMPILERS = %w(cc cxx objc asm)
COMMANDS = COMPILERS + %w(linker archiver yacc gperf git exts mrbc)
@@ -85,6 +85,8 @@ module MRuby
@build_mrbtest_lib_only = false
@cxx_abi_enabled = false
@cxx_exception_disabled = false
+ @enable_bintest = false
+ @enable_test = false
@toolchains = []
MRuby.targets[@name] = self
@@ -94,6 +96,7 @@ module MRuby
MRuby.targets[@name].instance_eval(&block)
build_mrbc_exec if name == 'host'
+ build_mrbtest if test_enabled?
end
def enable_debug
@@ -170,6 +173,18 @@ EOS
MRUBY_ROOT
end
+ def enable_test
+ @enable_test = true
+ end
+
+ def test_enabled?
+ @enable_test
+ end
+
+ def build_mrbtest
+ gem :core => 'mruby-test'
+ end
+
def build_mrbc_exec
gem :core => 'mruby-bin-mrbc'
end
@@ -252,7 +267,7 @@ EOS
mrbtest = exefile("#{build_dir}/bin/mrbtest")
sh "#{filename mrbtest.relative_path}#{$verbose ? ' -v' : ''}"
puts
- run_bintest if @enable_bintest
+ run_bintest if bintest_enabled?
end
def run_bintest
@@ -297,7 +312,7 @@ EOS
end
def run_test
- mrbtest = exefile("#{build_dir}/test/mrbtest")
+ mrbtest = exefile("#{build_dir}/bin/mrbtest")
if (@test_runner.command == nil)
puts "You should run #{mrbtest} on target device."
puts
diff --git a/travis_config.rb b/travis_config.rb
index 458473f96..4ee6d752b 100644
--- a/travis_config.rb
+++ b/travis_config.rb
@@ -22,6 +22,7 @@ MRuby::Build.new do |conf|
c.defines += %w(MRB_GC_FIXED_ARENA)
end
conf.enable_bintest
+ conf.enable_test
end
MRuby::Build.new('cxx_abi') do |conf|
@@ -33,18 +34,9 @@ MRuby::Build.new('cxx_abi') do |conf|
c.defines += %w(MRB_GC_FIXED_ARENA)
end
conf.enable_bintest
+ conf.enable_test
enable_cxx_abi
build_mrbc_exec
end
-
-MRuby::Build.new('test') do |conf|
- toolchain :gcc
-
- enable_debug
- conf.enable_bintest
-
- conf.gembox 'full-core'
- conf.gem :core => "mruby-test"
-end