1
1
mirror of https://github.com/casey/just.git synced 2024-11-23 11:04:09 +03:00

Bump version: 0.3.13 -> 0.4.0 (#401)

This commit is contained in:
Casey Rodarmor 2019-04-12 00:46:29 -07:00 committed by GitHub
parent fe0a6c252c
commit c3d1d9049f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 81 additions and 76 deletions

View File

@ -1,9 +1,17 @@
# Changelog
All notable changes to this project will be documented in this file.
## [v0.4.0] - 2019-04-12
### Added
- Add recipe aliases by @ryloric (#390)
- Allow arbitrary expressions as default arguments (#400)
- Add justfile summaries (#399)
- Allow outer shebang lines so justfiles can be used as scripts (#393)
- Allow `--justfile` without `--working-directory` by @smonami (#392)
- Add link to Chinese translation of readme by @chinanf-boy (#377)
The format is based on [Keep a Changelog](http://keepachangelog.com/en/1.0.0/)
and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0.html).
### Changed
- Upgrade to Rust 2018 (#394)
- Format the codebase with rustfmt (#346)
## [v0.3.13] - 2018-11-06
### Added

2
Cargo.lock generated
View File

@ -190,7 +190,7 @@ dependencies = [
[[package]]
name = "just"
version = "0.3.13"
version = "0.4.0"
dependencies = [
"ansi_term 0.11.0 (registry+https://github.com/rust-lang/crates.io-index)",
"assert_matches 1.3.0 (registry+https://github.com/rust-lang/crates.io-index)",

View File

@ -1,6 +1,6 @@
[package]
name = "just"
version = "0.3.13"
version = "0.4.0"
description = "🤖 Just a command runner"
authors = ["Casey Rodarmor <casey@rodarmor.com>"]
license = "CC0-1.0"

View File

@ -112,9 +112,7 @@ impl Parameter {
Parameter {
variadic: parameter.variadic,
name: parameter.name.to_owned(),
default: parameter
.default
.map(|expression| Expression::new(expression)),
default: parameter.default.map(Expression::new),
}
}
}

View File

@ -1,88 +1,87 @@
use executable_path::executable_path;
use std::{
process::Command,
time::{Duration, Instant},
};
use tempdir::TempDir;
#[cfg(unix)]
fn kill(process_id: u32) {
unsafe {
libc::kill(process_id as i32, libc::SIGINT);
}
}
mod unix {
use executable_path::executable_path;
use std::{
process::Command,
time::{Duration, Instant},
};
use tempdir::TempDir;
#[cfg(unix)]
fn interrupt_test(justfile: &str) {
let tmp = TempDir::new("just-interrupts").unwrap_or_else(|err| {
panic!(
"integration test: failed to create temporary directory: {}",
err
)
});
let mut justfile_path = tmp.path().to_path_buf();
justfile_path.push("justfile");
brev::dump(justfile_path, justfile);
let start = Instant::now();
let mut child = Command::new(&executable_path("just"))
.current_dir(&tmp)
.spawn()
.expect("just invocation failed");
while start.elapsed() < Duration::from_millis(500) {}
kill(child.id());
let status = child.wait().unwrap();
let elapsed = start.elapsed();
if elapsed > Duration::from_secs(2) {
panic!("process returned too late: {:?}", elapsed);
fn kill(process_id: u32) {
unsafe {
libc::kill(process_id as i32, libc::SIGINT);
}
}
if elapsed < Duration::from_millis(100) {
panic!("process returned too early : {:?}", elapsed);
fn interrupt_test(justfile: &str) {
let tmp = TempDir::new("just-interrupts").unwrap_or_else(|err| {
panic!(
"integration test: failed to create temporary directory: {}",
err
)
});
let mut justfile_path = tmp.path().to_path_buf();
justfile_path.push("justfile");
brev::dump(justfile_path, justfile);
let start = Instant::now();
let mut child = Command::new(&executable_path("just"))
.current_dir(&tmp)
.spawn()
.expect("just invocation failed");
while start.elapsed() < Duration::from_millis(500) {}
kill(child.id());
let status = child.wait().unwrap();
let elapsed = start.elapsed();
if elapsed > Duration::from_secs(2) {
panic!("process returned too late: {:?}", elapsed);
}
if elapsed < Duration::from_millis(100) {
panic!("process returned too early : {:?}", elapsed);
}
assert_eq!(status.code(), Some(130));
}
assert_eq!(status.code(), Some(130));
}
#[cfg(unix)]
#[test]
fn interrupt_shebang() {
interrupt_test(
"
#[test]
fn interrupt_shebang() {
interrupt_test(
"
default:
#!/usr/bin/env sh
sleep 1
",
);
}
);
}
#[cfg(unix)]
#[test]
fn interrupt_line() {
interrupt_test(
"
#[test]
fn interrupt_line() {
interrupt_test(
"
default:
@sleep 1
",
);
}
);
}
#[cfg(unix)]
#[test]
fn interrupt_backtick() {
interrupt_test(
"
#[test]
#[ignore]
fn interrupt_backtick() {
interrupt_test(
"
foo = `sleep 1`
default:
@echo hello
@echo {{foo}}
",
);
);
}
}