summaryrefslogtreecommitdiff
Commit message (Collapse)AuthorAgeFilesLines
...
| | | * | Add ability to have 'writable' cache servers.Daniel Silverstone2012-09-071-0/+19
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Since we need to be able to update the cache from builders, this patch introduces a --enable-writes argument to morph-cache-server and also adds a @writable decorator to the class ready for marking particular paths which are only available when --enable-writes is set.
| | | * | Support running on a different port from 8080Daniel Silverstone2012-09-071-1/+6
| | | | | | | | | | | | | | | | | | | | | | | | | In order to allow multiple morph-cache-server instances to run on a single system, we need to support running on different ports.
| | | * | Return tree SHA1 when looking for ref resolution.Daniel Silverstone2012-09-072-4/+14
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Morph now expects the tree SHA1 in addition when resolving references using the cache server. This is to better facilitate correct cache key computation since commits can be made which have no tree changes and thus nothing to usefully affect the build. (For example the morph branch and build features)
| | | * | A direct-mode for git cache accessDaniel Silverstone2012-09-072-9/+30
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Direct-mode, when enabled, causes morph-cache-server to assume a more Trove-like structure for the repositories, rather than the morph-cache structure which it was originally written for. This means that for the workers, we can use the original code and for Trove, the direct mode.
| | | * | Add a .gitignore to ignore *.pycDaniel Silverstone2012-09-071-0/+1
| | |/ / | | | | | | | | | | | | | | | | To reduce the noise when I run 'git status' this gitignore will mean that git won't notify me of repocache.pyc and __init__.pyc
| | * | Revert "Use the desired artifact filename as the download filename."Jannis Pohlmann2012-05-011-1/+0
| | | | | | | | | | | | | | | | This reverts commit f1fba299bd07510346082ef985ef08a494dca9d9.
| | * | Add /trees which serves the contents of a git tree using ls-tree.Jannis Pohlmann2012-04-202-0/+45
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | /trees queries take repo URI, a SHA1 ref and an optional path parameter. The result is a JSON dictionary of the form { "repo": "<repo URI>", "ref": "<SHA1 ref>", "tree": { "filename1": { "mode": "100644", "kind": "blob", "sha1": "FOOBARBAZ" }, ... } }
| | * | Use the desired artifact filename as the download filename.Jannis Pohlmann2012-04-181-0/+1
| | | |
| | * | Add support for /artifacts.Jannis Pohlmann2012-04-181-0/+17
| | | |
| | * | Fix various small issues preventing bundles from working.Jannis Pohlmann2012-04-182-3/+6
| | | |
| | * | Add untested support for bundles.Jannis Pohlmann2012-04-182-6/+25
| | | |
| | * | Use "Cache-Control: no-cache" to avoid caching of /sha1s results.Jannis Pohlmann2012-04-181-0/+1
| | | | | | | | | | | | | | | | | | | | | | | | Resolving a ref may result in a different SHA1 between any two requests, so we simply should never allow the results to be cached by an HTTP cache.
| | * | Raise a RepositoryNotFoundError if a repo does not exist in the cache.Jannis Pohlmann2012-04-182-2/+12
| | | |
| | * | Initial import implementing /files and /sha1s.Jannis Pohlmann2012-04-175-0/+259
| | /
| * | distbuild: allow daemons to bind to ephemeral portsRichard Maw2014-10-012-3/+28
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | You can bind to an ephemeral port by passing 0 as the port number. To work out which port you actually got, you need to call getsockname(). To facilitate being able to spawn multiple copies of the daemons for testing environments, you can pass a -file option, which will make the daemon write which port it actually bound to. If this path is a fifo, reading from it in the spawner process will allow synchronisation of only spawning services that require that port to be ready after it is.
| * | Fix and integrate distbuild unit testsRichard Maw2014-10-014-128/+133
| | |
| * | Allow default split rules to be overridden in-codeRichard Maw2014-10-011-4/+4
| | | | | | | | | | | | | | | | | | This is needed for distbuild to deserialise based on the split rules on the node that did the graph calculation, rather than the node that does the building.
| * | Remove remaining test.as-root cmdtestsRichard Maw2014-10-018-455/+0
| | | | | | | | | | | | | | | | | | The repo-alias is indirectly tested by branch-from-image, and checking the --version is part of the release process, so we're not going to miss these tests.
| * | Remove overlap detection logicRichard Maw2014-10-0110-438/+0
| | | | | | | | | | | | | | | | | | | | | I've rarely needed to use it, and on those rare occasions, it would have been easy enough to calculate it. Let's get rid of this step, and save everyone some time in future.
| * | Remove run-in-artifact subcommandRichard Maw2014-10-016-117/+1
| | | | | | | | | | | | It's easy enough to deploy the image.
| * | Remove tarball image format tests from tests.as-rootRichard Maw2014-10-014-157/+0
| | | | | | | | | | | | | | | | | | | | | We're implicitly testing it in yarns already. Explicit tests would be better, but removing the old test makes it easier to get rid of build-mode: test.
| * | Move architecture existing test to yarnRichard Maw2014-10-015-37/+31
| | |
| * | Move the branch-from-image test to a yarnRichard Maw2014-10-015-59/+49
| | |
| * | Make show-dependencies not use build-mode: testRichard Maw2014-10-011-25/+7
| | |
| * | Stop tests.branching needing build-mode: testRichard Maw2014-10-013-5/+5
| | | | | | | | | | | | | | | | | | It doesn't do any actual building, so it doesn't matter that using build-mode: bootstrap everywhere means that it would end up with an empty system artifact.
| * | Remove unused cmdtestsRichard Maw2014-10-0114-780/+0
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | tests.deploy is gone since we have yarn coverage instead. tests/setup had unnecessary setup in it, since the remaining tests require custom setup anyway. A bunch of tests were disabled anyway, so they're gone. Also, there was still code in ./check to run tests.merging, which have been gone for a while.
| * | Modify yarns to use test-shell instead of build-mode: testRichard Maw2014-10-014-167/+178
| | | | | | | | | | | | | | | When all the tests that use build-mode: test are gone, the build mode can be removed.
| * | Add test shell for use in staging area testsRichard Maw2014-10-011-0/+144
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This is intended to be statically linked, so it can be run in the staging area, without having to build a libc. You shouldn't generally statically link GLibc, because it dynamically links things like NSS modules or locale data, but we only need some very simple stuff, so we can get away with that. There's also potential licensing issues, as GLibc is LGPLv2, so distribution requires providing the ability to re-link against another library, but its use in the test-suite shouldn't count as distribution. There's a couple of commands, the only two needed by the yarn test suite are "copy files" which is like `cp -r . "$DESTDIR"`, and "false", which is for commands to deliberately fail.
* | | Merge branch 'sam/gbo-read-access'Sam Thursfield2014-10-071-2/+13
|\ \ \ | | | | | | | | | | | | | | | | Reviewed-By: Pedro Alvarez <pedro.alvarez@codethink.co.uk> Reviewed-By: Francisco Redondo Marchena <francisco.marchena@codethink.co.uk>
| * | | Never require SSH access to the Trove where baserock: content is hostedSam Thursfield2014-10-071-2/+13
| | |/ | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Previously if the user included 'baserock' in their list of trove-ids, the keyed URL expansions in the repo-alias field would change such that reading from git.baserock.org required SSH access. This isn't good and in particular breaks Mason, which by default isn't set up with a Gitano account on the Trove that it reads from, and therefore doesn't have SSH access to that Trove. With this change, the trove-id field will not cause the default 'baserock:' and 'upstream:' prefixes to be overridden, so setting 'trove-id = baserock' in morph.conf will not Morph's behaviour to change.
* | | Merge branch 'baserock/pedroalvarez/fix-xfer-hole'Pedro Alvarez2014-10-021-2/+8
|\ \ \ | | | | | | | | | | | | | | | | Reviewed-by: Pedro Alvarez Reviewed-by: Paul Sherwood
| * | | xfer-hole: Fix bug in copy_slice_from_file.Lars Wirzenius2014-10-021-2/+8
|/ / / | | | | | | | | | | | | os.read is limited to an int in size. copy_slice_from_file was trying to os.read more than that causing an OverflowError.
* | | Merge branch 'baserock/pedroalvarez/uuid-upgrades'Pedro Alvarez2014-10-021-2/+5
|\ \ \ | |_|/ |/| | | | | | | | Reviewed-by: Paul Sherwood Reviewed-by: Richard Maw
| * | ssh-rsync: gett UUID of the disk before writing fstabPedro Alvarez2014-10-011-2/+5
|/ / | | | | | | | | | | | | | | | | With this patch, the fstab of the system to be deployed as an upgrade will be conifgured using the UUID of the disk. Now when doing an upgrade is not needed to specify the ROOT_DEVICE.
* | Merge branch 'baserock/pedroalvarez/morph-version-fix'Pedro Alvarez2014-09-302-4/+7
|\ \ | |/ |/| | | | | | | Reviewed-by: Adam Coldrick Reviewed-by: Sam Thursfield Reviewed-by: Richard Maw
| * Fix behaviour of `morph --version`Pedro Alvarez2014-09-302-4/+7
|/ | | | | | | | | | | | | | | | Currently, if morph is installed in the system, `morph --version` prints the sha1 of the version installed. $ morph --version e8adedb8f3f27d9212caf277b8e8f7c6792a20c2 If you run morph from git, the output will be something similar to the following. $ morph --version baserock-14.26-124-g7b73af4 This patch changes the behaviour of the latter to match the former.
* Merge branch 'richardmaw/env-logging-fix'Sam Thursfield2014-09-241-2/+2
|\ | | | | | | | | Reviewed-By: Pedro Alvarez <pedro.alvarez@codethink.co.uk> Reviewed-By: Sam Thursfield <sam.thursfield@codethink.co.uk>
| * Safely interpolate in environment variable reportingRichard Maw2014-09-241-2/+2
|/ | | | | | | | | The msg parameter to status is a format string. If we pass a string directly to it, then we have to be careful to escape any formatting characters. However, we can just do the interpolation directly in the status call instead, which is less code.
* Add no cover to morphology hash functionRichard Ipsum2014-09-231-1/+1
|
* Merge branch 'baserock/richardmaw-os/tidy-build-logic-v7'Richard Maw2014-09-2229-2667/+2365
|\ | | | | | | | | | | Reviewed-by: Lars Wirzenius (+2 to misc fixups) Reviewed-by: Sam Thursfield (+1 to per-source building) Reviewed-by: Paul Sherwood (+1 to per-source building)
| * Remove Artifact compatibility methodsRichard Maw2014-09-193-40/+7
| |
| * Remove get_dependency_prefix_setRichard Maw2014-09-191-14/+0
| | | | | | | | | | | | | | | | This was used by artifacts to tell what they should put in their path, based on what prefixes were used earlier. This implementation didn't handle recursive deps, and it was trivial to open-code it at the call-site, so it is no longer useful.
| * Fix show-dependencies plugin to use source deps.Richard Maw2014-09-191-2/+2
| |
| * FIXUP: Fix unit tests after changing to per-source buildsRichard Maw2014-09-195-90/+28
| |
| * FIXUP: Cmdtest artifact listings after building per-sourceRichard Maw2014-09-192-2/+2
| |
| * Build per-source rather than per-artifactRichard Maw2014-09-196-297/+314
| |
| * FIXUP: Add compatibility methods to Artifact for fields that moved to SourceRichard Maw2014-09-192-2/+36
| | | | | | | | | | This means we can avoid having to rewrite everything immediately after the fields moved.
| * Move dependencies and cache keys to SourcesRichard Maw2014-09-192-22/+23
| |
| * FIXUP: Fix show-dependencies output to include source namesRichard Maw2014-09-191-1679/+1679
| | | | | | | | | | This patch has been split out of the previous one so that it is easier to review the changes. cmdtests do not pass without this change.
| * FIXUP: Fix up unit tests from change allowing multiple sourcesRichard Maw2014-09-199-276/+114
| | | | | | | | | | This is logically part of the previous patch, but has been split out to ease reviewing.