aboutsummaryrefslogtreecommitdiff
path: root/bbot/worker/worker.cxx
diff options
context:
space:
mode:
authorKaren Arutyunov <karen@codesynthesis.com>2020-09-17 22:45:41 +0300
committerKaren Arutyunov <karen@codesynthesis.com>2020-09-21 13:30:34 +0300
commit81564e819135be41c2634841bf48ce88b79731a0 (patch)
tree2aadaba7075f8f888338ad12c04b7c16846e6b1f /bbot/worker/worker.cxx
parentf46331d6bcceecc55915c4e940147d6135611d33 (diff)
Add support for modules that require bootstrap
Diffstat (limited to 'bbot/worker/worker.cxx')
-rw-r--r--bbot/worker/worker.cxx100
1 files changed, 68 insertions, 32 deletions
diff --git a/bbot/worker/worker.cxx b/bbot/worker/worker.cxx
index dd941ad..ade9060 100644
--- a/bbot/worker/worker.cxx
+++ b/bbot/worker/worker.cxx
@@ -630,6 +630,23 @@ build (size_t argc, const char* argv[])
rwd = current_directory ();
+ // If this is a build system module that requires bootstrap, then its
+ // importation into the dependent (test) projects cannot be configured and
+ // the corresponding config.import.* variable needs to be specified on the
+ // bpkg/build2 command line as a global override, whenever required.
+ //
+ // Note that such a module must be explicitly marked with `requires:
+ // bootstrap` in its manifest. This can only be detected after the module
+ // is configured and it's manifest available.
+ //
+ bool bootstrap (false);
+
+ // Note that we will parse the package manifest right after the package is
+ // configured.
+ //
+ package_manifest pm;
+ path mf (pkg_dir / "manifest"); // Relative to the configuration directory.
+
if (module)
{
// Configure.
@@ -720,6 +737,19 @@ build (size_t argc, const char* argv[])
break;
rm.status |= r.status;
+
+ // Note that being unable to parse the package manifest is likely to
+ // be an infrastructure problem, given that the package has been
+ // successfully configured.
+ //
+ pm = parse_manifest<package_manifest> (mf, "package");
+
+ bootstrap = find_if (pm.requirements.begin (),
+ pm.requirements.end (),
+ [] (const requirement_alternatives& r)
+ {
+ return r.size () == 1 && r[0] == "bootstrap";
+ }) != pm.requirements.end ();
}
// Update.
@@ -761,6 +791,10 @@ build (size_t argc, const char* argv[])
// Use --package-cwd to help ported to build2 third-party packages a
// bit (see bpkg-pkg-test(1) for details).
//
+ // Note that internal tests that load the module itself don't make
+ // much sense, thus we don't pass the config.import.* variable on
+ // the command line for modules that require bootstrap.
+ //
// bpkg test <package-name>
//
r.status |= run_bpkg (
@@ -780,6 +814,14 @@ build (size_t argc, const char* argv[])
// The "main" step.
//
+ // Use the global override for modules that require bootstrap.
+ //
+ string module_import (
+ module
+ ? ((bootstrap ? "!config.import." : "config.import.") +
+ tm.name.variable () + "=" + (rwd / module_dir).string ())
+ : "");
+
// Configure.
//
dir_path build_dir ("build"); // Configuration directory name.
@@ -797,13 +839,8 @@ build (size_t argc, const char* argv[])
//
{
// If the package is a build system module, then make sure it is
- // importable in this configuration.
+ // importable in this configuration (see above about bootstrap).
//
- string import (module
- ? ("config.import." + tm.name.variable () + "=" +
- module_dir.string ())
- : "");
-
r.status |= run_bpkg (
trace, r.log, wre,
"-V",
@@ -813,7 +850,7 @@ build (size_t argc, const char* argv[])
step_args (modules, step_id::bpkg_configure_create),
step_args (env_args, step_id::bpkg_configure_create),
cargs,
- import.empty () ? nullptr : import.c_str ());
+ module && !bootstrap ? module_import.c_str () : nullptr);
if (!r.status)
break;
@@ -871,6 +908,8 @@ build (size_t argc, const char* argv[])
if (!r.status)
break;
+
+ pm = parse_manifest<package_manifest> (mf, "package");
}
rm.status |= r.status;
@@ -917,26 +956,6 @@ build (size_t argc, const char* argv[])
"test") != prj.operations.end ();
}
- // Parse the package manifest.
- //
- // Note that being unable to parse the package manifest is likely to be an
- // infrastructure problem, given that the package has been successfully
- // configured.
- //
- path mf (pkg_config / pkg_dir / "manifest");
- package_manifest pm (parse_manifest<package_manifest> (mf, "package"));
-
- // A build system module that requires bootstrap must be explicitly marked
- // with `requires: bootstrap`.
- //
- bool bootstrap (module &&
- find_if (pm.requirements.begin (),
- pm.requirements.end (),
- [] (const requirement_alternatives& r)
- {
- return r.size () == 1 && r[0] == "bootstrap";
- }) != pm.requirements.end ());
-
// Run the package external tests, if specified. But first filter them
// against the test-exclude task manifest values using the package names.
//
@@ -967,8 +986,9 @@ build (size_t argc, const char* argv[])
bool external_tests (!pm.tests.empty ());
// Configure, update, and test packages in the bpkg configuration in the
- // current working directory. Optionally set the environment variables for
- // bpkg processes. Return true if all operations for all packages succeed.
+ // current working directory. Optionally pass the config.import.* variable
+ // override and/or set the environment variables for bpkg processes.
+ // Return true if all operations for all packages succeed.
//
// Note that we assume that these packages belong to the dependent
// package's repository or its complement repositories, recursively. Thus,
@@ -977,6 +997,7 @@ build (size_t argc, const char* argv[])
//
auto test = [&pm, &trace, &wre, &step_args, &config_args, &env_args]
(operation_result& r,
+ const char* import = nullptr,
const small_vector<string, 1>& envvars = {})
{
for (const test_dependency& td: pm.tests)
@@ -990,6 +1011,17 @@ build (size_t argc, const char* argv[])
//
// bpkg.configure.build
//
+ // @@ Note that this currently fails for packages that use modules
+ // requiring bootstrap that come from git repositories (unless
+ // special measures are taken to omit the module for info and dist
+ // meta-oprations) since the package checkout involves build2 dist
+ // meta-operation to which the import variable override is not
+ // passed (it is supposed to be passed later, when the checked out
+ // package is being configured). This issue should be gone when
+ // bpkg is fixed to run the build2 dist meta-operation in some
+ // special (not yet implemented) "bootstrap" mode which doesn't
+ // load the project.
+ //
r.status |= run_bpkg (
envvars,
trace, r.log, wre,
@@ -999,6 +1031,7 @@ build (size_t argc, const char* argv[])
"--yes",
step_args (env_args, step_id::bpkg_configure_build),
step_args (config_args, step_id::bpkg_configure_build),
+ import,
"--",
td.string ());
@@ -1018,6 +1051,7 @@ build (size_t argc, const char* argv[])
"update",
step_args (env_args, step_id::bpkg_update_update),
step_args (config_args, step_id::bpkg_update_update),
+ import,
pkg);
if (!r.status)
@@ -1040,6 +1074,7 @@ build (size_t argc, const char* argv[])
"--package-cwd", // See above for details.
step_args (env_args, step_id::bpkg_test_test),
step_args (config_args, step_id::bpkg_test_test),
+ import,
pkg);
if (!r.status)
@@ -1049,7 +1084,7 @@ build (size_t argc, const char* argv[])
return true;
};
- if ((internal_tests || external_tests) && !bootstrap) //@@ TMP
+ if (internal_tests || external_tests)
{
operation_result& r (test_result != nullptr
? *test_result
@@ -1078,7 +1113,8 @@ build (size_t argc, const char* argv[])
// Run external tests.
//
- if (external_tests && !test (r))
+ if (external_tests &&
+ !test (r, bootstrap ? module_import.c_str () : nullptr))
break;
rm.status |= r.status;
@@ -1332,7 +1368,7 @@ build (size_t argc, const char* argv[])
// Build/test.
//
- if (!test (r, envvars))
+ if (!test (r, nullptr /* import */, envvars))
break;
}