summaryrefslogtreecommitdiff
path: root/main.go
AgeCommit message (Collapse)Author
2024-07-28Wait for VM to bootxengineering
This waits for a little delay and then tries to run `true` via SSH on the virtual machine. If this does not work for a maximum amount of attempts a fatal error is raised and an appropriate log message is written.
2024-07-21Move from busybox ash to shxengineering
`busybox` is not installed inside the current VM and there is no strict reason to use it. `sh` instead should be present on any targeted system.
2024-07-21Startup VM parallel to craft execution on hostxengineering
This prepares moving the workbench to the virtual machine. It furthermore adds the following command line arguments: - image - port See `craft --help` or the init() function for details.
2024-07-21Remove craft.sh concept / add --task argumentxengineering
There will likely be a way how a source repository can specify the default shell commands to build itself for craft. If this will be a pure shell file, YAML, JSON or something else is not clear for now. This commit removes the lookup of the craft.sh file and instead adds the --task command line argument to specify that script code. This might only be a temporary solution but is the best fit for now.
2024-07-21Add missing docs for -repo and -commitxengineering
2024-07-21Switch order of startup and exit log messagexengineering
While the exit log message is prefixed with `defer` and thus called at the end of the main function it is in theory possible that the startup log message fails. This would result in a exit message without startup message which is confusing. Furthermore it is not intuitive while reading the code to see the exit message first.
2024-07-20Drop Git hook logicxengineering
This might be re-used later but the new goal is to make craft an independent build automation tool or service which might be called by a later provided git hook. Nevertheless the primary target for now is to build something which executes a build based on a repository reference but not triggered by a Git hook.
2024-07-06Execute build function from craft.shxengineering
craft.sh is the script which needs to be located inside the repository root to define how the repository should be used. The first defined function is `build()` which is used to build the repository content.
2024-07-06Improve submodule update performance significantlyxengineering
This commit add the usage of shallow submodule updates. Thus after checking out the targeted commit of the parent repository only the required commits of the submodules are fetched.
2024-07-06Implement recursive submodule updatexengineering
This adds support for repositories having submodules. Nevertheless all the required clone operations are complete which makes this process time consuming depending on the list of submodules.
2024-07-06Prepare simple workbenchxengineering
After detecting an update of a Git ref craft should create a throw-away Git clone of the repository with the new Git commit checked out. This is the starting point for executing build and test steps. Improving performance by tree-less or shallow clones and updating submodules is not yet implemented.
2024-07-06Modify log outputxengineering
- exit message - more consistent messages - refactoring to implement this
2024-07-05Determine and validate Git hook typexengineering
Since craft should only be referenced by a symlink like that: ln -s /usr/bin/craft myrepo/.git/hooks/post-receive It is important to detect the hook type, in this case 'post-receive'. This commit also validates that the determined hook type is supported. Currently only the post-receive hook is supported.
2024-07-05Print current working directoryxengineering
When craft is used - as intended - as Git post-receive hook the current working directory should always be the .git folder. In case of bare repositories this should point to the bare repository.
2023-09-02Add stdin parsing for Git post-receive hookxengineering
The first program for this repsoitory will be a Git post-receive hook which will be used at any source repository which is registered for automated builds.