Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

chore(deps): update dependency python-semantic-release to v9 #69

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

ziltoidbot
Copy link

@ziltoidbot ziltoidbot commented Dec 30, 2024

This PR contains the following updates:

Package Type Update Change
python-semantic-release (changelog) dev-dependencies major ^7.32.2 -> ^9.0.0

Release Notes

python-semantic-release/python-semantic-release (python-semantic-release)

v9.17.0

Compare Source

Bug Fixes
  • github-action: Disable writing python bytecode in action execution
    (#​1152,
    315ae21)

File permission issues can occur when using the github-action and dynamically loading files from the
repository. When importing, python generally will create bytecode files and write to disk as the
current user. Because the default user in the github action is root, those files are written as
root which means when it returns to the rest of the workflow, those files cannot be modified or
deleted. With this change, we disable writing of bytecode files which prevents any failures that
may result after the python-semantic-release action is executed.

Features
  • changelog: Add sort_numerically filter function to template environment
    (#​1146,
    7792388)
  • test(helpers): add unit tests for various prefixed number lists

  • test(changelog-context): add unit tests to validate use of sort_numerically filter

  • test(release-notes-context): add unit tests to validate use of sort_numerically filter

  • refactor(util): relocate sort_numerically function to top level

  • docs(changelog-templates): add description for new sort_numerically filter function

  • config: Extend support of remote urls aliased using git insteadOf configurations
    (#​1151,
    4045037)

Resolves: #​1150

  • refactor(hvcs): add validation of git urls upon vcs client initialization

  • test(hvcs): refactor unit test to catch validation error immediately of bad git url

  • test(config): add test case of a git insteadOf aliased origin

  • test(parser-angular): update unit tests for parser return value compatibility

  • test(parser-scipy): update unit tests for parser return value compatibility

  • test(parser-emoji): update unit tests for parser return value compatibility

  • feat(version): parse squashed commits individually

adds the functionality to separately parse each commit message within a squashed merge commit to
detect combined commit types that could change the version bump

  • feat(changelog): parse squashed commits individually

adds functionality to separately parse each commit message within a squashed merge commit which
decouples the commits into their respective type categories in the changelog.

  • refactor(helpers): centralize utility for applying multiple text substitutions

  • feat(parser-angular): upgrade angular parser to parse squashed commits individually

Resolves: #​1085

  • feat(parser-angular): apply PR/MR numbers to all parsed commits from a squash merge

  • feat(parser-emoji): add functionality to interpret scopes from gitmoji commit messages

  • feat(parser-emoji): upgrade emoji parser to parse squashed commits individually

  • test(fixtures): adjust parser for squashed commit definitions

  • test(fixtures): change config of github flow repo to parse squash commits

  • test(fixtures): add fixture to create gitlab formatted merge commit

  • refactor(parser-scipy): standardize all category spelling applied to commits

  • docs(commit-parsing): add description for squash commit evaluation option of default parsers

  • docs(configuration): update the commit_parser_options setting description

Performance Improvements
  • refactor: adjust logging output

v9.16.1

Compare Source

Bug Fixes
  • parser-custom: Handle relative parent directory paths to module file better
    (#​1142,
    c4056fc)

The dynamic import originally would just replace "/" with "." to make the import module name more
pythonic, however this would be problematic in monorepos which would use
"../../misc/commit_parser.py" to locate the parser and so the resulting sys.modules entry would
have numerous periods (.) as a prefix. This removes that possibility. Still always an issue if the
imported module name matches an existing module but the likelihood is low.

Documentation
  • github-actions: Update PSR versions in github workflow examples
    (#​1140,
    9bdd626)

v9.16.0

Compare Source

Bug Fixes
  • changelog: Fixes PSR release commit exclusions for customized commit messages
    (#​1139,
    f9a2078)
  • fix(config-changelog): validate changelog.exclude_commit_patterns on config load

  • test(fixtures): relocate sanitize changelog functions

  • test(cmd-version): add test to validate that custom release messages are ignored in changelog

  • test(config): add changelog.exclude_commit_patterns validation check

  • style(config): refactor import names of re module

  • cmd-version: Fix --print-tag result to match configured tag format
    (#​1134,
    a990aa7)
  • test(fixtures): add new trunk repo that has a different tag format

  • test(fixtures): add helper to extract config settings from repo action definition

  • test(cmd-version): expand testing of --print-tag & --print-last-released-tag

PSR did not have enough testing to demonstrate testing of the tag generation when the tag format was
configured differently than normal. This commit adds a significant portion of testing to exercise
the print tag functionality which must match the configured tag format.

  • cmd-version: Fix tag format on default version when force bump for initial release
    (#​1138,
    007fd00)

Resolves: #​1137

  • test(fixtures): add new unreleased trunk repo with a different tag format

  • test(cmd-version): ensure forced bump version on initial release follows tag format

ref: #​1137

Features
  • config: Expand dynamic parser import to handle a filepath to module
    (#​1135,
    0418fd8)
  • test(fixtures): remove import checking/loading of custom parser in use_custom_parser

  • test(config): extend import parser unit tests to evaluate file paths to modules

  • docs(commit-parsing): add the new custom parser import spec description for direct path imports

Resolves: #​687

  • docs(configuration): adjust commit_parser option definition for direct path imports

v9.15.2

Compare Source

Bug Fixes
  • changelog: Ensures user rendered files are trimmed to end with a single newline
    (#​1118,
    6dfbbb0)

  • cli: Add error message of how to gather full error output
    (#​1116,
    ba85532)

  • cmd-version: Enable maintenance prereleases
    (#​864,
    b88108e)

  • test(fixtures): improve changelog generator to filter by max version

  • test(fixtures): add repo fixture of a trunk only repo w/ dual version support

  • test(fixtures): add repo fixture of a trunk only repo w/ dual version support & prereleases

  • test(cmd-version): add rebuild repo tests for new dual version support repos

  • test(version-determination): adjust unit tests of increment_version logic

This clarifies repeated function calls and pytest parameter names included the unclear assert diff.
Adds additional tests to check bad states for failures and refactored to match new function
signature.

  • fix(version-bump): increment based on current commit's history only

Refactor duplicate logging messages and flow to process out odd cases in a fail fast methodology.
This removes the reliance on any last full release that is not within the history of the current
branch.

Resolves: #​861

  • cmd-version: Fix handling of multiple prerelease token variants & git flow merges
    (#​1120,
    8784b9a)
  • refactor: define a custom logging level of silly

  • fix(version): remove some excessive log msgs from debug to silly level

  • test(fixtures): refactor builder functions for version file updates

  • test(fixtures): adjust build command to handle versions w/ build metadata

  • test(fixtures): fix gitflow repo that included an invalid build metadata string

  • test(fixtures): fix major_on_zero setting in repos to match expected behavior

  • test(cmd-version): add test cases to run an example repo rebuild w/ psr

  • test(cmd-version): enable git flow repo rebuild w/ psr test cases

  • fix(cmd-version): handle multiple prerelease token variants properly

In the case where there are alpha and beta releases, we must only consider the previous beta release
even if alpha releases exist due to merging into beta release only branches which have no changes
considerable changes from alphas but must be marked otherwise.

Resolves: #​789

  • fix(cmd-version): fix version determination algorithm to capture commits across merged branches

  • perf(cmd-version): refactor version determination algorithm for accuracy & speed

  • test(algorithm): refactor test to match new function signature

  • style(algorithm): drop unused functions & imports

  • test(algorithm): adapt test case for new DFS commit traversal implementation

  • cmd-version: Forces tag timestamp to be same time as release commit
    (#​1117,
    7898b11)

  • config: Ensure default config loads on network mounted windows environments
    (#​1124,
    a64cbc9)

Resolves: #​1123

  • test(cmd-generate-config): added noop version execution to validate config at runtime

ref: #​1123

v9.15.1

Compare Source

Bug Fixes
  • changelog-md: Fix commit sort of breaking descriptions section
    (75b342e)

  • parser-angular: Ensure issues are sorted by numeric value rather than text sorted
    (3858add)

  • parser-emoji: Ensure issues are sorted by numeric value rather than text sorted
    (7b8d2d9)

v9.15.0

Compare Source

Bug Fixes
  • cmd-version: Ensure release utilizes a timezone aware datetime
    (ca817ed)

  • default-changelog: Alphabetically sort commit descriptions in version type sections
    (bdaaf5a)

Features
  • commit-parser: Enable parsers to flag commit to be ignored for changelog
    (#​1108,
    0cc668c)

This adds an attribute to the ParsedCommit object that allows custom parsers to set to false if it
is desired to ignore the commit completely from entry into the changelog.

Resolves: #​778

  • test(parser-custom): add test w/ parser that toggles if a parsed commit is included in changelog
  • default-changelog: Add a separate formatted breaking changes section
    (#​1110,
    4fde30e)

Resolves: #​244

  • test(fixtures): update repo changelog generator to add breaking descriptions

  • test(default-changelog): add unit tests to demonstrate breaking change descriptions

  • test(release-notes): add unit tests to demonstrate breaking change descriptions

  • feat(changelog-md): add a breaking changes section to default Markdown template

  • feat(changelog-rst): add a breaking changes section to default reStructuredText template

  • feat(changelog-md): alphabetize breaking change descriptions in markdown changelog template

  • feat(changelog-rst): alphabetize breaking change descriptions in ReStructuredText template

  • default-changelog: Alphabetize commit summaries & scopes in change sections
    (#​1111,
    8327068)
  • test(fixtures): force non-alphabetical release history to validate template sorting

  • test(default-changelog): update unit test to enforce sorting of commit desc in version sections

  • test(release-notes): update unit test to enforce sorting of commit desc in version sections

  • feat(changelog-md): alphabetize commit summaries & scopes in markdown changelog template

  • feat(changelog-rst): alphabetize commit summaries & scopes in ReStructuredText template

  • parsers: Enable parsers to identify linked issues on a commit
    (#​1109,
    f90b8dc)
  • refactor(parsers): add parser option validation to commit parsing

  • docs(api-parsers): add option documentation to parser options

  • feat(parsers): add other_allowed_tags option for commit parser options

  • feat(parser-custom): enable custom parsers to identify linked issues on a commit

  • test(parser-angular): add unit tests to verify parsing of issue numbers

  • test(parser-emoji): add unit tests to verify parsing of issue numbers

  • test(parser-scipy): add unit tests to verify parsing of issue numbers

  • fix(util): prevent git footers from being collapsed during parse

  • feat(parser-angular): automatically parse angular issue footers from commit messages

  • feat(parser-emoji): parse issue reference footers from commit messages

  • docs(commit-parsing): improve & expand commit parsing w/ parser descriptions

  • docs(changelog-templates): update examples using new commit.linked_issues attribute

  • chore(docs): update documentation configuration for team publishing

  • release-notes: Add tag comparison link to release notes when supported
    (#​1107,
    9073344)
  • test(release-notes): adjust test case to include a version compare link

  • test(cmd-changelog): add test to ensure multiple variants of release notes are published

v9.14.0

Compare Source

Bug Fixes
  • release-notes: Override default wordwrap to non-wrap for in default template
    (99ab99b)
Documentation
  • changelog-templates: Document new mask_initial_release changelog context variable
    (f294957)

  • configuration: Document new mask_initial_release option usage & effect
    (3cabcdc)

  • homepage: Fix reference to new ci workflow for test status badge
    (6760069)

Features
  • changelog: Add md to rst conversion for markdown inline links
    (cb2af1f)

  • changelog: Define first release w/o change descriptions for default MD template
    (fa89dec)

  • changelog: Define first release w/o change descriptions for default RST template
    (e30c94b)

  • changelog-md: Add markdown inline link format macro
    (c6d8211)

  • changelogs: Prefix scopes on commit descriptions in default template
    (#​1093,
    560fd2c)

  • test(changelog): update default changelog unit tests to handle commit scope

  • test(release-notes): update default release notes unit tests to handle commit scope

  • test(fixtures): update changelog generator fixture to handle scope additions

  • test(cmd-version): update implementation for test resiliency

  • feat(changelog-md): prefix scopes on commit descriptions in Markdown changelog template

  • feat(changelog-rst): prefix scopes on commit descriptions in ReStructuredText template

  • configuration: Add changelog.default_templates.mask_initial_release option
    (595a70b)

  • context: Add mask_initial_release setting to changelog context
    (6f2ee39)

  • release-notes: Define first release w/o change descriptions in default template
    (83167a3)

v9.13.0

Compare Source

Bug Fixes
  • changelog-rst: Ignore unknown parsed commit types in default RST changelog
    (77609b1)

  • parser-angular: Drop the breaking category but still maintain a major level bump
    (f1ffa54)

  • parsers: Improve reliability of text unwordwrap of descriptions
    (436374b)

Documentation
  • changelog-templates: Add linked_merge_request field to examples
    (d4376bc)

  • changelog-templates: Fix api class reference links
    (7a5bdf2)

  • commit-parsing: Add linked_merge_request field to Parsed Commit definition
    (ca61889)

Features
  • changelog: Add PR/MR url linking to default Markdown changelog
    (cd8d131)

Resolves: #​924, #​953

  • changelog: Add PR/MR url linking to default reStructuredText template
    (5f018d6)

Resolves: #​924, #​953

  • parsed-commit: Add linked merge requests list to the ParsedCommit object
    (9a91062)

  • parser-angular: Automatically parse PR/MR numbers from subject lines in commits
    (2ac798f)

  • parser-emoji: Automatically parse PR/MR numbers from subject lines in commits
    (bca9909)

  • parser-scipy: Automatically parse PR/MR numbers from subject lines in commits
    (2b3f738)

Performance Improvements
  • parser-angular: Simplify commit parsing type pre-calculation
    (a86a28c)

  • parser-emoji: Increase speed of commit parsing
    (2c9c468)

  • parser-scipy: Increase speed & decrease complexity of commit parsing
    (2b661ed)

v9.12.2

Compare Source

Bug Fixes
  • cli: Gracefully capture all exceptions unless in very verbose debug mode
    (#​1088,
    13ca44f)
  • refactor(cli): consolidate entrypoints into the module execute file
  • hvcs-*: Add flexibility to issue & MR/PR url jinja filters
    (#​1089,
    275ec88)
  • fix(github): fix issue_url filter to ignore an issue prefix gracefully

  • fix(github): fix pull_request_url filter to ignore an PR prefix gracefully

  • fix(gitlab): fix issue_url filter to ignore an issue prefix gracefully

  • fix(gitlab): fix merge_request_url filter to ignore an PR prefix gracefully

  • fix(gitea): fix issue_url filter to ignore an issue prefix gracefully

  • fix(gitea): fix pull_request_url filter to ignore an PR prefix gracefully

  • fix(bitbucket): fix pull_request_url filter to ignore an PR prefix gracefully

  • test(bitbucket): add test case for prefixed PR numbers

  • test(gitea): add test case for prefixed PR & issue numbers

  • test(gitlab): add test case for prefixed PR & issue numbers

  • test(github): add test case for prefixed PR & issue numbers

  • style(hvcs): fix logical lint errors

  • docs(changelog-templates): update descriptions of issue & MR/PR url jinja filters

v9.12.1

Compare Source

Bug Fixes
  • changelog: Fix raw-inline pattern replacement in convert_md_to_rst filter
    (2dc70a6)

  • cmd-version: Fix --as-prerelease when no commit change from last full release
    (#​1076,
    3b7b772)

  • release-notes: Add context variable shorthand ctx like docs claim & changelog has
    (d618d83)

Documentation
  • contributing: Update local testing instructions
    (74f03d4)

v9.12.0

Compare Source

Bug Fixes
  • changelog: Ignore commit exclusion when a commit causes a version bump
    (e8f886e)

  • parser-angular: Change Fixes commit type heading to Bug Fixes
    (#​1064,
    09e3a4d)

  • test(fixtures): update expected changelog heading to Bug Fixes

  • test(unit): update expected changelog heading to Bug Fixes

  • parser-emoji: Enable the default bump level option
    (bc27995)
Documentation
  • commit-parsers: Add deprecation message for the tag parser
    (af94540)

  • configuration: Add deprecation message for the tag parser
    (a83b7e4)

Features
  • changelog: Add autofit_text_width filter to template environment
    (#​1062,
    83e4b86)

This change adds an equivalent style formatter that can apply a text alignment to a maximum width
and also maintain an indent over paragraphs of text

  • docs(changelog-templates): add definition & usage of autofit_text_width template filter

  • test(changelog-context): add test cases to check autofit_text_width filter use

v9.11.1

Compare Source

Bug Fixes
  • changelog: Prevent custom template errors when components are in hidden folders
    (#​1060,
    a7614b0)

v9.11.0

Compare Source

Features
  • changelog: Add default changelog template in reStructuredText format
    (#​1055,
    c2e8831)
  • test(fixtures): update repo generation to create rst & md changelogs

  • test(release-history): refactor fragile test to utilize repo fixture definitions

  • test(changelog-cmd): update tests to evaluate rst changelog generation & updates

  • test(version-cmd): update tests to evaluate rst changelog generation & updates

  • test(version-cmd): update test code to match new commit definition functions

  • test(config): add test to validate insertion_flag default determination

  • feat(changelog): add convert_md_to_rst filter to changelog environment

  • feat(changelog): add default changelog in re-structured text format

This change adds the templates to create an equivalent CHANGELOG.RST file in angular changelog
style. It can be enabled via the output_format configuration setting.

Resolves: #​399

  • feat(config): enable target changelog filename to trigger RST output format

  • feat(config): enable default changelog.insertion_flag based on output format

  • refactor(config): move changelog_file setting under changelog.default_templates

This change adds a secondary changelog_file setting under the default_templates section while
deprecating the top level one. Since this is not intended to be a breaking change we provided a
warning message and compatibility code to pass along the current changelog_file value to the new
setting location while giving the user a notification to update before the next version.

  • fix(changelog): correct spacing for default markdown template during updates

  • docs(configuration): update details of insertion_flag's dynamic defaults with rst

  • docs(configuration): update output_format description for reStructuredText support

  • docs(configuration): update changelog_file with deprecation notice of setting relocation

  • docs(changelog): clarify the convert_md_to_rst filter added to the template environment

  • docs(changelog): increase detail about configuration options of default changelog creation

v9.10.1

Compare Source

Bug Fixes

prevents stacktrace error when user provided regex for a branch name match is invalid. Translates
most common failure of a plain wildcard * character to the implied proper regex

v9.10.0

Compare Source

Documentation
  • github-actions: Update primary example with workflow sha controlled pipeline
    (14f04df)
Features
  • changelog: Modify changelog template to support changelog updates
    (#​1045,
    c18c245)
  • feat(changelog): add read_file function to changelog template context

This feature adds a filter that will enable jinja templates to read a file from the repository into
memory to then use as output within the template. The primary use for this is to read in a
previous changelog file which then the template can give the illusion of insertion as it re-writes
the entire file.

  • feat(changelog): add changelog_mode to changelog template context

Adds a flag that can be passed to the templating environment to allow for triggering an update mode
of a changelog versions an initialization mode. The usage is up to the template developer but for
PSR it is used to handle changelog generation vs changelog updating.

  • feat(changelog): add prev_changelog_file to changelog template context

This adds a string that represents a filename to a previous changelog file which can be read from
inside the template context. The primary use is for enabling the updating of a changelog through
jinja templating.

  • feat(changelog): add changelog_insertion_flag to changelog template context

This adds a customizable string to the jinja templating context which allows users to use the PSR
configuration to pass a custom insertion flag into the templating context. This is intended for
use with initializing a changelog and then updating it from that point forward.

  • feat(changelog): add shorthand ctx variable to changelog template env

  • refactor(changelog): change recursive render to not use file streaming

It would be nice to maintain file streaming for better memory usage but it prevents the ability to
read the file contents previously from within the template which is a desire in order to insert
into a previous changelog. In this case, the memory usage is likely not a problem for large text
files.

  • fix(config): prevent jinja from autoescaping markdown content by default

Since this project is generally rendering non-html content such as RST or MD, change the default of
the jinja autoescape parameter to false instead of true. When it was true, it would automatically
convert any & ampersands to its htmlentity equivalent & which is completely unnecessary
and unreadable in non-html documents.

  • docs(configuration): update changelog.environment.autoescape default to false to match code

  • docs(configuration): standardize all true/false to lowercase ensuring toml-compatibility

  • feat(config): add changelog.mode as configuration option

  • feat(config): add changelog.insertion_flag as configuration option

  • refactor(config): use changelog.changelog_file as previous changelog file for target for update

  • style(config): alphabetize changelog configuration options

  • docs(configuration): add changelog.mode and changelog.insertion_flag config definitions

  • fix(changelog): adjust angular heading names for readability

  • feat(changelog): modify changelog template to support changelog updates

By popular demand, the desire to only prepend new information to the changelog is now possible given
the changelog.mode = update configuration option.

Resolves: #​858, #​722

  • refactor(errors): add new generic internal error for tragic improbable flaws

  • fix(changelog): ensure changelog templates can handle complex directory includes

  • feat(config): add changelog.default_templates.output_format config option

  • fix(changelog): only render user templates when files exist

This change ensures that we will use our default even when the user only overrides the release notes
template. It also must have jinja templates in the folder otherwise we will render the default
changelog.

  • refactor(changelog): enable default changelog rendering of multiple template parts

  • refactor(changelog): change rendering of default release notes to new template structure

  • refactor(context): use pathlib instead of context manager to read file

  • test(fixtures): update changelog generator format & angular heading names

  • test(angular): adjust test of commit type to section header

  • test(changelog): update make changelog context function call

  • test(release-notes): update test related to release notes generation

  • test(fixtures): add processing to filter out repo definitions for partial changelogs

  • test(fixtures): update repo generators to update changelogs w/ every version

  • test(fixtures): slow down repo generators to prevent git failures from same timestamps

  • test(fixtures): update changelog generator to include insertion flag

  • refactor(changelog): fix template to handle update when no releases exist

  • refactor(changelog): adjust template to use improved release object

  • refactor(changelog): improve resilence & non-existant initial changelog

  • style(changelog-templates): maintain 2-spaces indentation throughout jinja templates

  • refactor(changelog): ensure cross-platform template includes with jinja compatibility

  • test(changelog-cmd): add tests to evaluate variations of the changelog update mode

  • test(version-cmd): add tests to evaluate variations of the changelog update mode

  • refactor(release-notes): normalize line endings to universal newlines & always end with newline

  • refactor(changelog): ensure default changelog renders w/ universal newlines & writes as
    os-specific

  • test(changelog): update changelog testing implementation to be newline aware

  • test: update tests to use cross-platform newlines where appropriate

  • docs(changelog-templates): improve detail & describe new changelog.mode="update"

  • docs(configuration): mark version of configuration setting introduction

  • docs(homepage): update custom changelog reference

  • refactor(changelog): adjust read_file filter to read file as os-newline aware

  • refactor(changelog): apply forced universal newline normalizer on default changelog

  • test(changelog): adjust implementation to consistently work on windows

  • test(version): adjust implementation to consistently work on windows

  • refactor(changelog-template): only add insertion flag if in update mode

  • test(changelog): adjust test to handle changelog regeneration in init mode

  • refactor(changelog-templates): adjust init template to clean up extra newlines

  • test(changelog): adjust expected output after cleaned up newlines

  • docs(configuration): define the new changelog.default_templates.output_format option

  • github-actions: Add an action build directive to toggle the --skip-build option
    (#​1044,
    26597e2)
  • docs(commands): update definition of the version commands --skip-build option

  • docs(github-actions): add description of the build input directive

v9.9.0

Compare Source

Documentation
  • github-actions: Clarify & consolidate GitHub Actions usage docs
    (#​1011,
    2135c68)

Resolves: #​907

  • chore(scripts): remove non-existant file from version bump script

  • docs(automatic-releases): drop extrenous github push configuration

  • docs(homepage): remove link to old github config & update token scope config

  • docs(github-actions): expand descriptions & clarity of actions configs

  • docs(github-actions): add configuration & description of publish action

  • docs(github-actions): revert removal of namespace prefix from examples

Features
  • github-actions: Add is_prerelease output to the version action
    (#​1038,
    6a5d35d)
  • test(github-actions): add test to ensure is_prerelease is a action output

  • docs(github-actions): add description of new is_prerelease output for version action

v9.8.9

Compare Source

Bug Fixes
  • version-cmd: Improve version_variables flexibility w/ quotes (ie. json, yaml, etc)
    (#​1028,
    156915c)
  • fix(version-cmd): increase version_variable flexibility with quotations (ie. json, yaml, etc)

Previously json would not work due to the key being wrapped in quotes, yaml also has issues when it
does not usually use quotes. The regex we created originally only wrapped the version to be
replaced in quotes but now both the key and version can optionally be wrapped in different kind of
quotations.

Resolves: #​601, #​706, #​962, #​1026

  • docs(configuration): add clarity to version_variables usage & limitations

Ref: #​941

  • fix(version-cmd): ensure version_variables do not match partial variable names

  • build(deps-test): add PyYAML as a test dependency

  • test(fixtures): refactor location of fixture for global use of cli runner

  • test(stamp-version): add test cases to stamp json, python, & yaml files

Documentation

set ignore-module-all for autodoc_default_options to resolve some Sphinx errors about duplicate
/ ambiguous references https://github.com/sphinx-doc/sphinx/issues/4961#issuecomment-1543858623

Standardize some non-standard (Google-ish) docstrings to Sphinx format, to avoid ruff and Sphinx
arguing about underline length.

Fix indents and other minor whitespace / formatting changes.

Fixes #​1029

v9.8.8

Compare Source

Bug Fixes
  • config: Fix path traversal detection for windows compatibility
    (#​1014,
    16e6daa)

The original implementation of the path traversal detection expected that resolve() works the same
on windows as it does with Linux/Mac. Windows requires the folder paths to exist to be resolved
and that is not the case when the template_dir is not being used.

Resolves: #​994

Documentation
  • configuration: Update build_command env table for windows to use all capital vars
    (0e8451c)

  • github-actions: Update version in examples to latest version
    (3c894ea)

v9.8.7

Compare Source

Bug Fixes
  • Provide context.history global in release notes templates
    (#​1005,
    5bd91b4)
  • fix(release-notes): provide context.history global in release note templates

Temporarily return the context.history variable to release notes generation as many users are
using it in their release documentation. It was never intended to be provided and will be removed
in the future.

context was removed in v9.8.3 during a refactor and condensing of changelog and release notes
functionality.

Resolves: #​984

  • fix(release-notes): fix noop-changelog to print raw release notes

Some markdown sequences can be interpreted as ansi escape sequences which dilute debugging of
release note templates by the user. This change ensures the raw content is displayed to the
console as expected.

Documentation
  • docs(github-actions): use pinned version for GHA examples

Fixes #​1003

  • chore(scripts): add auto version bump to non dynamic docs text (i.e. code snippets)

  • docs(github-actions): adjust formatting & version warning in code snippets

  • style(docs-github-actions): adjust formatting for readability


Co-authored-by: codejedi365 <codejedi365@​gmail.com>

  • changelog: Clarify description of the default changelog generation process
    (399fa65)

  • configuration: Clarify changelog_file vs template_dir option usage
    (a7199c8)

Provided additional description that warns about the mutually-exclusive nature of the
changelog_file option and the template_dir option.

Resolves: #​983

  • configuration: Fix build_command_env table rendering
    (#​996,
    a5eff0b)

v9.8.6

Compare Source

Bug Fixes
  • version-cmd: Resolve build command execution in powershell
    (#​980,
    32c8e70)

Fixes the command line option for passing a shell command to Powershell. Also included a similar
shell detection result for pwsh (Powershell Core)

Documentation
  • configuration: Correct GHA parameter name for commit email
    (#​981,
    ce9ffdb)

git_committer_name was repeated; replace one instance of it with git_committer_email

v9.8.5

Compare Source

Bug Fixes
  • Enable --print-last-released* when in detached head or non-release branch
    (#​926,
    782c0a6)
  • test(version-cmd): add tests to print when detached or non-release branch

ref: #​900

  • fix(version-cmd): drop branch restriction for --print-last-released* opts

Resolves: #​900

Performance Improvements
  • Improve git history processing for changelog generation
    (#​972,
    bfda159)
  • perf(changelog): improve git history parser changelog generation

This converts the double for-loop (O(n^2)) down to O(n) using a lookup table to match the
current commit with a known tag rather than iterating through all the tags of the repository every
time.

  • fix(changelog): resolve commit ordering issue when dates are similar

v9.8.4

Compare Source

Bug Fixes
  • **change

Configuration

📅 Schedule: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined).

🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.

Rebasing: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.

🔕 Ignore: Close this PR and you won't be reminded about this update again.


  • If you want to rebase/retry this PR, check this box

This PR has been generated by Renovate Bot.

@ziltoidbot
Copy link
Author

⚠️ Artifact update problem

Renovate failed to update an artifact related to this branch. You probably do not want to merge this PR as-is.

♻ Renovate will retry this branch, including artifacts, only when one of the following happens:

  • any of the package files in this branch needs updating, or
  • the branch becomes conflicted, or
  • you click the rebase/retry checkbox if found above, or
  • you rename this PR's title to start with "rebase!" to trigger it manually

The artifact failure details are included below:

File name: poetry.lock
Updating dependencies
Resolving dependencies...


The current project's Python requirement (>=3.7,<4.0) is not compatible with some of the required packages Python requirement:
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8
  - python-semantic-release requires Python >=3.8, so it will not be satisfied for Python >=3.7,<3.8

Because no versions of python-semantic-release match >=9.0.0,<9.0.2 || >9.0.2,<9.0.3 || >9.0.3,<9.1.0 || >9.1.0,<9.1.1 || >9.1.1,<9.2.0 || >9.2.0,<9.2.1 || >9.2.1,<9.2.2 || >9.2.2,<9.3.0 || >9.3.0,<9.3.1 || >9.3.1,<9.4.0 || >9.4.0,<9.4.1 || >9.4.1,<9.4.2 || >9.4.2,<9.5.0 || >9.5.0,<9.6.0 || >9.6.0,<9.7.0 || >9.7.0,<9.7.1 || >9.7.1,<9.7.2 || >9.7.2,<9.7.3 || >9.7.3,<9.8.0 || >9.8.0,<9.8.1 || >9.8.1,<9.8.2 || >9.8.2,<9.8.3 || >9.8.3,<9.8.4 || >9.8.4,<9.8.5 || >9.8.5,<9.8.6 || >9.8.6,<9.8.7 || >9.8.7,<9.8.8 || >9.8.8,<9.8.9 || >9.8.9,<9.9.0 || >9.9.0,<9.10.0 || >9.10.0,<9.10.1 || >9.10.1,<9.11.0 || >9.11.0,<9.11.1 || >9.11.1,<9.12.0 || >9.12.0,<9.12.1 || >9.12.1,<9.12.2 || >9.12.2,<9.13.0 || >9.13.0,<9.14.0 || >9.14.0,<9.15.0 || >9.15.0,<9.15.1 || >9.15.1,<9.15.2 || >9.15.2,<10.0.0
 and python-semantic-release (9.0.2) requires Python >=3.8, python-semantic-release is forbidden.
And because python-semantic-release (9.0.3) requires Python >=3.8, python-semantic-release is forbidden.
And because python-semantic-release (9.1.0) requires Python >=3.8
 and python-semantic-release (9.1.1) requires Python >=3.8, python-semantic-release is forbidden.
And because python-semantic-release (9.2.0) requires Python >=3.8
 and python-semantic-release (9.2.1) requires Python >=3.8, python-semantic-release is forbidden.
And because python-semantic-release (9.2.2) requires Python >=3.8
 and python-semantic-release (9.3.0) requires Python >=3.8, python-semantic-release is forbidden.
And because python-semantic-release (9.3.1) requires Python >=3.8
 and python-semantic-release (9.4.0) requires Python >=3.8, python-semantic-release is forbidden.
And because python-semantic-release (9.4.1) requires Python >=3.8
 and python-semantic-release (9.4.2) requires Python >=3.8, python-semantic-release is forbidden.
And because python-semantic-release (9.5.0) requires Python >=3.8
 and python-semantic-release (9.6.0) requires Python >=3.8, python-semantic-release is forbidden.
And because python-semantic-release (9.7.0) requires Python >=3.8
 and python-semantic-release (9.7.1) requires Python >=3.8, python-semantic-release is forbidden.
And because python-semantic-release (9.7.2) requires Python >=3.8
 and python-semantic-release (9.7.3) requires Python >=3.8, python-semantic-release is forbidden.
And because python-semantic-release (9.8.0) requires Python >=3.8
 and python-semantic-release (9.8.1) requires Python >=3.8, python-semantic-release is forbidden.
And because python-semantic-release (9.8.2) requires Python >=3.8
 and python-semantic-release (9.8.3) requires Python >=3.8, python-semantic-release is forbidden.
And because python-semantic-release (9.8.4) requires Python >=3.8
 and python-semantic-release (9.8.5) requires Python >=3.8, python-semantic-release is forbidden.
And because python-semantic-release (9.8.6) requires Python >=3.8
 and python-semantic-release (9.8.7) requires Python >=3.8, python-semantic-release is forbidden.
And because python-semantic-release (9.8.8) requires Python >=3.8
 and python-semantic-release (9.8.9) requires Python >=3.8, python-semantic-release is forbidden.
And because python-semantic-release (9.9.0) requires Python >=3.8
 and python-semantic-release (9.10.0) requires Python >=3.8, python-semantic-release is forbidden.
And because python-semantic-release (9.10.1) requires Python >=3.8
 and python-semantic-release (9.11.0) requires Python >=3.8, python-semantic-release is forbidden.
And because python-semantic-release (9.11.1) requires Python >=3.8
 and python-semantic-release (9.12.0) requires Python >=3.8, python-semantic-release is forbidden.
And because python-semantic-release (9.12.1) requires Python >=3.8
 and python-semantic-release (9.12.2) requires Python >=3.8, python-semantic-release is forbidden.
And because python-semantic-release (9.13.0) requires Python >=3.8
 and python-semantic-release (9.14.0) requires Python >=3.8, python-semantic-release is forbidden.
And because python-semantic-release (9.15.0) requires Python >=3.8
 and python-semantic-release (9.15.1) requires Python >=3.8, python-semantic-release is forbidden.
So, because python-semantic-release (9.15.2) requires Python >=3.8
 and mailerlite depends on python-semantic-release (^9.0.0), version solving failed.

  • Check your dependencies Python requirement: The Python requirement can be specified via the `python` or `markers` properties
    
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"
    For python-semantic-release, a possible solution would be to set the `python` property to ">=3.8,<4.0"

    https://python-poetry.org/docs/dependency-specification/#python-restricted-dependencies,
    https://python-poetry.org/docs/dependency-specification/#using-environment-markers

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants