// file : build2/test/init.cxx -*- C++ -*- // copyright : Copyright (c) 2014-2017 Code Synthesis Ltd // license : MIT; see accompanying LICENSE file #include #include #include #include #include #include #include #include using namespace std; using namespace butl; namespace build2 { namespace test { static rule rule_; static alias_rule alias_rule_; void boot (scope& rs, const location&, unique_ptr&) { tracer trace ("test::boot"); l5 ([&]{trace << "for " << rs.out_path ();}); // Register the test operation. // rs.operations.insert (test_id, test); // Enter module variables. Do it during boot in case they get assigned // in bootstrap.build. // auto& vp (var_pool); // Note: none are overridable. // // The test variable is a name which can be a path (with the // true/false special values) or a target name. // vp.insert ("test", variable_visibility::target); vp.insert ("test.input", variable_visibility::project); vp.insert ("test.output", variable_visibility::project); vp.insert ("test.roundtrip", variable_visibility::project); vp.insert ("test.options", variable_visibility::project); vp.insert ("test.arguments", variable_visibility::project); // These are only used in testscript. // vp.insert ("test.redirects", variable_visibility::project); vp.insert ("test.cleanups", variable_visibility::project); // Test target platform. // // Unless already set, default test.target to build.host. Note that it // can still be overriden by the user, e.g., in root.build. // { value& v ( rs.assign ( vp.insert ( "test.target", variable_visibility::project))); if (!v || v.empty ()) v = cast ((*global_scope)["build.host"]); } } bool init (scope& rs, scope&, const location& l, unique_ptr&, bool first, bool, const variable_map& config_hints) { tracer trace ("test::init"); if (!first) { warn (l) << "multiple test module initializations"; return true; } const dir_path& out_root (rs.out_path ()); l5 ([&]{trace << "for " << out_root;}); assert (config_hints.empty ()); // We don't known any hints. //@@ TODO: Need ability to specify extra diff options (e.g., // --strip-trailing-cr, now hardcoded). // Adjust module priority so that the config.test.* values are saved at // the end of config.build. // // if (s) // config::save_module (r, "test", INT32_MAX); // Register target types. // { auto& t (rs.target_types); t.insert (); } // Register rules. // { auto& r (rs.rules); // Register our test running rule. // r.insert (perform_test_id, "test", rule_); r.insert (perform_test_id, "test", alias_rule_); // Register our rule for the dist meta-operation. We need to do this // because we may have ad hoc prerequisites (test input/output files) // that need to be entered into the target list. // r.insert (dist_id, test_id, "test", rule_); } return true; } } }