- 
2f5966bd
by Raoul Hidalgo Charman
at 2018-12-05T10:37:10Z
 platform.py: Add mapping of uname to OS-independent values
 
- 
1ad35fcd
by Raoul Hidalgo Charman
at 2018-12-05T10:44:02Z
 _config.py: Use os and architecture settings
In element, platform asks for host os and architecture to default to when
SandboxConfig is initialised.
This changes element cache keys so those have been updated in the tests.
 
- 
9f75c274
by Raoul Hidalgo Charman
at 2018-12-05T10:44:02Z
 optionarch.py: update to use same arch names as SandboxConfig
Also update tests to be consistent with this
 
- 
a825096c
by Raoul Hidalgo Charman
at 2018-12-05T10:44:02Z
 _sandboxremote.py: Add os and arch to command uploaded
These are contained within the platform field.
 
- 
8e09a81c
by Raoul Hidalgo Charman
at 2018-12-05T10:44:02Z
 optionos.py: Add new option for OS configuration
 
- 
defec112
by Raoul Hidalgo Charman
at 2018-12-05T10:44:02Z
 optionos.py: Add tests for OptionOS
Same format as OptionArch tests, but with OS's.
 
- 
e5d8c7d8
by Raoul Hidalgo Charman
at 2018-12-05T10:44:02Z
 _platform: Add checks for os and architecture
 
- 
b0603fb0
by Raoul Hidalgo Charman
at 2018-12-05T10:44:02Z
 Sandbox: use linux32 for x86-32 builds on x86-64 machines
  o _platform/linux.py: Add linux32 flag to send to sandbox bwrap when the
    build arch is x86-32 and the machines arch is x86-64 or similarly with
    aarch32 and aarch64.
  o sandbox/_sandboxbwrap.py: Use flag passed to start bwrap command with
    linux32 if set.
- 
f4d76996
by Raoul Hidalgo Charman
at 2018-12-05T14:58:49Z
 format_project.rst: Update documentation for changes to OptionArch
 
- 
81163a79
by Raoul Hidalgo Charman
at 2018-12-05T14:58:53Z
 format_declaring.rst: Update documentation for sandbox options
 
- 
23c27580
by Raoul Hidalgo Charman
at 2018-12-05T14:58:53Z
 format_project.rst: Add docs for OptionOS
 
- 
eb1ed410
by Jürg Billeter
at 2018-12-05T15:28:52Z
 Merge branch 'raoul/775-execution-environment-reqs' into 'master'
Execution environment reqs
Closes #775
See merge request BuildStream/buildstream!969 
- 
9ef1a8a2
by Raoul Hidalgo Charman
at 2018-12-05T15:32:22Z
 utils.py: Add message digest function
Get cascache.py to use this
 
- 
4a56bf2a
by Raoul Hidalgo Charman
at 2018-12-05T15:33:44Z
 _sandboxremote.py: Add checks to action cache before attempting to push.
Stops unneccesary pushing of builds that have already been built, just checks
the action cache to begin with.
Fixes #628
 
- 
3641b6f6
by Raoul Hidalgo Charman
at 2018-12-05T15:33:44Z
 _sandboxremote.py: Add action-cache-service endpoint
The endpoint may not necessarily be the same as execution-service endpoint.
Part of #628
 
- 
9d77351f
by Raoul Hidalgo Charman
at 2018-12-05T15:33:44Z
 format_project.rst: Add docs for action-cache-service
Part of #628
 
- 
a53d6d1f
by Raoul Hidalgo Charman
at 2018-12-05T16:36:00Z
 Merge branch 'raoul/628-RE-flow-optimisation' into 'master'
Remote-execution client flow optimisation
Closes #628
See merge request BuildStream/buildstream!982 
- 
4688b2c9
by Tristan Van Berkom
at 2018-12-06T07:35:59Z
 tests/sources/git.py: Refactor ref-not-in-track test to use parameterization
Instead of duplicating the whole test body, run it twice while
checking for a warning or an error depending on the parameter.
 
- 
03028c7f
by Tristan Van Berkom
at 2018-12-06T07:35:59Z
 types.py: Moving CoreWarnings to the types.py module
This also ensures it is exposed via the main buildstream __init__.py
file, fixes the imports of CoreWarnings, and adjusts the documentation
links to point to the right place.
 
- 
3b7f8df8
by Tristan Van Berkom
at 2018-12-06T07:35:59Z
 Source: Fix typo in documentation, and make it a link to `bst track`
Now the commands have documentation linkability so we can link to
them when referring to them anywhere in the docs. This reference
was previously referring to a bogus non-existent `build-stream track`,
maybe this dates way back to the days before we named the frontend `bst`.
 
- 
e5c0f067
by Tristan Van Berkom
at 2018-12-06T07:35:59Z
 git source plugin: Fixing documentation linking and typo
Fixes the configurable warning part of this to properly link
to the project.conf documentation describing what configurable
warnings actually are.
Also fix the plugin raise the actual configurable warning which
it advertizes that it raises; which is 'inconsistent-submodule',
not 'inconsistent-submodules'.
 
- 
205c27d8
by Tristan Van Berkom
at 2018-12-06T07:35:59Z
 git source plugin: Rename symbol for consistency and readability
Change 'INCONSISTENT_SUBMODULE' for 'WARN_INCONSISTENT_SUBMODULE' to
make things a bit more readable and comprehensive.
 
- 
bea4d4f5
by Tristan Van Berkom
at 2018-12-06T09:37:50Z
 Merge branch 'tristan/misc-cleanup' into 'master'
Misc cleanups
See merge request BuildStream/buildstream!993 
- 
b1d2f001
by Tristan Van Berkom
at 2018-12-06T14:18:31Z
 source.py: Add new delegate method validate_cache()
This is guaranteed to be called only once for a given session once the
sources are known to be Consistency.CACHED, if source tracking is enabled
in the session for this source, then this will only be called if the
sources become cached after tracking completes.
 
- 
ee7fc47f
by Tristan Van Berkom
at 2018-12-06T14:18:31Z
 git source plugin: Implementing submodule warnings
 o Unlisted submodule warning
   Now the git plugin will issue a configurable warning if a submodule
   exists and is used (checking out the submodule is not disabled),
   but is not specified in the source configuration.
 o Invalid submodule warning
   Now the git source plugin will issue a warning if the configuration
   specified a submodule which does not exist in the underlying git repository.
As a side effect, this patch also changes the flow control of the git
plugin such that submodules which are explicitly set to not be
checked out, are also not fetched but instead ignored completely.
 
- 
5fc9a1da
by Tristan Van Berkom
at 2018-12-06T14:18:31Z
 git source plugin: Emmit the ref-not-in-track warning from validate_cache()
Now that we have Source.validate_cache(), this is a better place to emmit
the ref-not-in-track warning, since it will be emmitted at the earliest
opportunity and not only at Source.stage() or Source.init_workspace().
This also allows us to remove the `self.tracked` local state, and cleanup
some convoluted calling paths, removing some unnecessary parameters from
the usual codepaths and making the plugin overall more readable.
 
- 
50cb2706
by Tristan Van Berkom
at 2018-12-06T14:18:31Z
 tests/testutils/repo/git.py: Adding remove_path() helper
A function for removing paths from a git repo, can also
be used to remove submodules.
 
- 
f139ca8f
by Tristan Van Berkom
at 2018-12-06T14:18:31Z
 tests/sources/git.py: Testing the git:unlisted-submodule warning
 o Test that it is not triggered in show before fetch, because we
   don't know about the unlisted submodules yet
 o Test that it is triggered by a fetch command
 o Test that it is triggered by `show` after having completed a
   fetch command, since now we have the repository and know about
   the unlisted submodule
 o Test all of this under warning or error conditions (parameterized
   for fatal-warnings)
 
- 
afe1aa9f
by Tristan Van Berkom
at 2018-12-06T14:18:31Z
 tests/sources/git.py: Testing the git:invalid-submodule warning
   o Test that it is not triggered in show before fetch, because we
     don't know the submodules yet so we cannot know if they are
     valid or not.
   o Test that it is triggered by a fetch command
   o Test that it is triggered by `show` after having completed a
     fetch command, since now we have the repository and know which
     specified submodules are invalid
   o Test all of this under warning or error conditions (parameterized
     for fatal-warnings)
- 
57300201
by Tristan Van Berkom
at 2018-12-06T14:18:31Z
 tests/sources/git.py: Test unlisted submodules warning appearing after track
 
- 
a0297625
by Tristan Van Berkom
at 2018-12-06T14:18:31Z
 tests/sources/git.py: Test invalid submodules warning appearing after track
 
- 
60e96781
by Tristan Van Berkom
at 2018-12-06T15:14:37Z
 Merge branch 'tristan/submodule-warnings' into 'master'
Implement submodule warnings
See merge request BuildStream/buildstream!996 
- 
7fe55143
by Jonathan Maw
at 2018-12-06T15:48:12Z
 Fix bst source-checkout not working with open workspaces
 
- 
2a6879a5
by Jonathan Maw
at 2018-12-06T17:46:33Z
 Merge branch 'jonathan/source-checkout-workspace' into 'master'
Fix bst source-checkout not working with open workspaces
Closes #807
See merge request BuildStream/buildstream!997 
- 
e61e6e50
by Tristan Van Berkom
at 2018-12-07T07:57:13Z
 _yaml.py: Added `allow_none` parameter to _yaml.node_get()
This allows specifying whether or not the code believes a None
value is acceptable if explicitly expressed to be None in the YAML.
A previous patch 3ba544b80f9f268be8ffe62fc8589b30212ec4a2 changed
the behavior to accept None for all values across the board, along
with allowing explicitly setting the `default_value` to `None` which
caused the code to be much more readable (this was the main motivation
of the patch, but it had the side effect of allowing None for everything).
In the majority of cases we load YAML however, it either has a value or
it is not specified in the YAML, and None is hardly ever acceptable
to be explicitly specified (it may be in the case you want to override
something with nothing in the YAML, but it is the edge case).
This had the side effect of causing unexpected crashes where the
YAML specifies an empty dictionary for instance.
Instead of forcing the caller to handle a possible None value, give
the choice to the caller if they really want to accept a None value,
and raise the LoadError otherwise.
This fixes issue #803, which is a crash due to receival of an
unexpected None value through _yaml.node_get()
 
- 
504ecb3e
by Tristan Van Berkom
at 2018-12-07T07:57:56Z
 plugin.py: Added new `allow_none` parameter to Plugin.node_get_member(), defaulting to False.
Allow plugins to conveniently leverage the new `allow_none` parameter,
and have Plugin.node_get_member() raise a LoadError in the usual
case where None is not an acceptable value to be explicitly set in
the user provided YAML.
 
- 
642ae4e8
by Tristan Van Berkom
at 2018-12-07T07:57:56Z
 tests/format/project.py: Added new regression test for empty dependency dictionaries
This adds a regression test for issue #803
 
- 
2a0676c3
by Tristan Van Berkom
at 2018-12-07T08:33:14Z
 Merge branch 'tristan/yaml-optionally-allow-none' into 'master'
Only optionally allow None values in user provided YAML
Closes #803
See merge request BuildStream/buildstream!999 
- 
6d3033fb
by Tom Pollard
at 2018-12-07T12:00:56Z
 WIP: Opening a workspace with a cached build