Skip generating changelog in tests

Changelog generation requires annotating commits with a commit type,
otherwise the tests will fail. This is annoying for contributors, since
it's unusual, and I often myself forget to do it, causing a round-trip
with tests.

So, skip generating the changelog during the tests. Also, change the
`--no-git` option for `gen book` and `gen all` to `--no-changelog`, so
it's clearer what it does.

I think I'll wind up just making a YAML file that contains commit types,
for changelog generation, so it doesn't have to be done in the commit
message.

type: testing
This commit is contained in:
Casey Rodarmor 2021-01-08 22:04:27 -08:00
parent 76ea6e5ed7
commit 61bbd3bad5
No known key found for this signature in database
GPG Key ID: 556186B153EC6FE0
2 changed files with 14 additions and 29 deletions

View File

@ -43,13 +43,6 @@ jobs:
steps: steps:
- uses: actions/checkout@v2 - uses: actions/checkout@v2
if: github.event_name == 'pull_request'
with:
ref: ${{ github.event.pull_request.head.sha }}
fetch-depth: 0
- uses: actions/checkout@v2
if: github.event_name != 'pull_request'
with: with:
fetch-depth: 0 fetch-depth: 0
@ -115,7 +108,7 @@ jobs:
if: matrix.os == 'macos-latest' if: matrix.os == 'macos-latest'
run: | run: |
brew install help2man brew install help2man
cargo run --package gen -- --bin target/debug/imdl all cargo run --package gen -- --bin target/debug/imdl all --no-changelog
git diff --no-ext-diff --exit-code git diff --no-ext-diff --exit-code
- name: Install `mdbook` - name: Install `mdbook`
@ -127,7 +120,7 @@ jobs:
- name: Build Book - name: Build Book
if: matrix.os != 'windows-latest' if: matrix.os != 'windows-latest'
run: | run: |
cargo run --package gen -- --bin target/debug/imdl book cargo run --package gen -- --bin target/debug/imdl book --no-changelog
mdbook build book --dest-dir ../www/book mdbook build book --dest-dir ../www/book
- name: Record Git Revision - name: Record Git Revision

View File

@ -4,21 +4,13 @@ use crate::common::*;
pub(crate) enum Subcommand { pub(crate) enum Subcommand {
#[structopt(about("Update all generated docs"))] #[structopt(about("Update all generated docs"))]
All { All {
#[structopt( #[structopt(long = "no-changelog", help = "Don't generate the changelog.")]
long = "no-git", no_changelog: bool,
help = "Skip generated outputs that require a Git repository. Currently this only includes \
the changelog."
)]
no_git: bool,
}, },
#[structopt(about("Generate book"))] #[structopt(about("Generate book"))]
Book { Book {
#[structopt( #[structopt(long = "no-changelog", help = "Don't generate the changelog.")]
long = "no-git", no_changelog: bool,
help = "Skip book contents require a Git repository. Currently this only includes the \
changelog."
)]
no_git: bool,
}, },
#[structopt(about("Generate the changelog"))] #[structopt(about("Generate the changelog"))]
Changelog, Changelog,
@ -84,21 +76,21 @@ impl Subcommand {
} }
Self::CompletionScripts => Self::completion_scripts(&project)?, Self::CompletionScripts => Self::completion_scripts(&project)?,
Self::Readme => Self::readme(&project)?, Self::Readme => Self::readme(&project)?,
Self::Book { no_git } => Self::book(&project, no_git)?, Self::Book { no_changelog } => Self::book(&project, no_changelog)?,
Self::Man => Self::man(&project)?, Self::Man => Self::man(&project)?,
Self::Diff => Self::diff(&project)?, Self::Diff => Self::diff(&project)?,
Self::All { no_git } => Self::all(&project, no_git)?, Self::All { no_changelog } => Self::all(&project, no_changelog)?,
} }
} }
#[throws] #[throws]
pub(crate) fn all(project: &Project, no_git: bool) { pub(crate) fn all(project: &Project, no_changelog: bool) {
if !no_git { if !no_changelog {
Self::changelog(&project)?; Self::changelog(&project)?;
} }
Self::completion_scripts(&project)?; Self::completion_scripts(&project)?;
Self::readme(&project)?; Self::readme(&project)?;
Self::book(&project, no_git)?; Self::book(&project, no_changelog)?;
Self::man(&project)?; Self::man(&project)?;
} }
@ -195,7 +187,7 @@ impl Subcommand {
} }
#[throws] #[throws]
pub(crate) fn book(project: &Project, no_git: bool) { pub(crate) fn book(project: &Project, no_changelog: bool) {
info!("Generating book…"); info!("Generating book…");
let gen = project.gen()?; let gen = project.gen()?;
@ -230,11 +222,11 @@ impl Subcommand {
Introduction::new(&project.config).render_to(out.join("introduction.md"))?; Introduction::new(&project.config).render_to(out.join("introduction.md"))?;
let include_changelog = !no_git; let include_changelog = !no_changelog;
Summary::new(project, include_changelog).render_to(out.join("SUMMARY.md"))?; Summary::new(project, include_changelog).render_to(out.join("SUMMARY.md"))?;
if !no_git { if !no_changelog {
let changelog = Changelog::new(&project)?; let changelog = Changelog::new(&project)?;
let dst = out.join("changelog.md"); let dst = out.join("changelog.md");
fs::write(&dst, changelog.render(true)?).context(error::Filesystem { path: dst })?; fs::write(&dst, changelog.render(true)?).context(error::Filesystem { path: dst })?;