Skip to content

Commit

Permalink
handle_run tests and bug fixes
Browse files Browse the repository at this point in the history
  • Loading branch information
pnordahl committed Nov 14, 2024
1 parent 3699abd commit db7788a
Show file tree
Hide file tree
Showing 6 changed files with 240 additions and 101 deletions.
3 changes: 3 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,9 @@
### Changed
Removed `--target (-t)` flag from `monorail analyze`

### Fixed
Issue preventing `monorail run` from returning non-zero exit codes

## [3.5.0] - 2024-11-13

### Changed
Expand Down
7 changes: 4 additions & 3 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -224,13 +224,14 @@ Defining a command can be done automatically by accepting `monorail` defaults, o

#### Automatic

By default, targets store their commands in a `monorail` directory relative to the target's path. The stem of the file becomes the command name. For example:
By default, targets store their commands in a `monorail/cmd` directory relative to the target's path. The stem of the file becomes the command name. For example:

```sh
repo/
one/
monorail/
build.sh
cmd/
build.sh
```

This defines the `build` command for the `one` target.
Expand Down Expand Up @@ -299,7 +300,7 @@ This will run `build` first for `dep1`, and then `target1` and `target2` in para

#### Arguments

Commands can be provided with positional arguments at runtime. There are two mechanism for doing this; the base argmap, and as flags provided to `monorail run`. In your command executables, capture these positional arguments as you would in any program in that language.
Commands can be provided with positional arguments at runtime. There are two mechanism for doing this; the base argmap, and as flags provided to `monorail run`. In your command executables, capture these positional arguments as you would in any program in that language. As is common, index 0 of the positional arguments is always an absolute path to the executable, so any additional arguments begin at index 1.

##### Base argmap
The base argmap is an optional file containing argument mappings, which, if provided, is automatically loaded before any other argument mappings provided to `monorail run`. This is useful for specifying static parameterization for commands, especially when a command executable is generic and reused among multiple targets. An example of this useful pattern is shown in https://github.com/pnordahl/monorail-example in the rust crate targets.
Expand Down
20 changes: 10 additions & 10 deletions src/api/cli.rs
Original file line number Diff line number Diff line change
Expand Up @@ -43,8 +43,8 @@ pub const ARG_STDOUT: &str = "stdout";
pub const ARG_ID: &str = "id";
pub const ARG_DEPS: &str = "deps";
pub const ARG_ARG: &str = "arg";
pub const ARG_ARG_MAP: &str = "argmap";
pub const ARG_ARG_MAP_FILE: &str = "argmap-file";
pub const ARG_ARGMAP: &str = "argmap";
pub const ARG_ARGMAP_FILE: &str = "argmap-file";
pub const ARG_FAIL_ON_UNDEFINED: &str = "fail-on-undefined";
pub const ARG_NO_BASE_ARGMAPS: &str = "no-base-argmaps";

Expand Down Expand Up @@ -291,8 +291,8 @@ Refer to --help for more information on these options.
.long_help("This is a shorthand form of the more expressive '--target-argmap' and '--target-argmap-file', designed for single command + single target use. Providing this flag without specifying exactly one command and one target will result in an error.")
)
.arg(
Arg::new(ARG_ARG_MAP)
.long(ARG_ARG_MAP)
Arg::new(ARG_ARGMAP)
.long(ARG_ARGMAP)
.short('m')
.num_args(1..)
.required(false)
Expand All @@ -318,8 +318,8 @@ See `monorail run -h` for information on how this interacts with other arg-relat
"#),
)
.arg(
Arg::new(ARG_ARG_MAP_FILE)
.long(ARG_ARG_MAP_FILE)
Arg::new(ARG_ARGMAP_FILE)
.long(ARG_ARGMAP_FILE)
.short('f')
.num_args(1..)
.required(false)
Expand Down Expand Up @@ -756,13 +756,13 @@ impl<'a> TryFrom<&'a clap::ArgMatches> for app::run::HandleRunInput<'a> {
.into_iter()
.flatten()
.collect(),
arg_map: cmd
.get_many::<String>(ARG_ARG_MAP)
argmap: cmd
.get_many::<String>(ARG_ARGMAP)
.into_iter()
.flatten()
.collect(),
arg_map_file: cmd
.get_many::<String>(ARG_ARG_MAP_FILE)
argmap_file: cmd
.get_many::<String>(ARG_ARGMAP_FILE)
.into_iter()
.flatten()
.collect(),
Expand Down
6 changes: 1 addition & 5 deletions src/app/checkpoint.rs
Original file line number Diff line number Diff line change
Expand Up @@ -166,11 +166,7 @@ mod tests {
let result = handle_checkpoint_update(&cfg, &input, rp).await;
assert!(result.is_ok());
let output = result.unwrap();
assert!(
// number of files in the test config
output.checkpoint.pending.unwrap().len() == 17,
"Pending changes should be populated"
);
assert!(!output.checkpoint.pending.unwrap().is_empty());
assert_eq!(output.checkpoint.id, head);
}

Expand Down
Loading

0 comments on commit db7788a

Please sign in to comment.