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

--amend option removes all git history #294

Closed
jawoznia opened this issue Jul 27, 2023 · 2 comments
Closed

--amend option removes all git history #294

jawoznia opened this issue Jul 27, 2023 · 2 comments
Labels
bug Something isn't working

Comments

@jawoznia
Copy link

git-auto-commit Version

v4

Machine Type

Ubuntu (eg. ubuntu-latest)

Bug description

I try to create a workflow that will update PRs on change. I don't want to create a new commit and would prefer to amend the automatic change to head commit in PR.

What I found is that for some reason the whole history is replaced with single new commit.

Steps to reproduce

It should be enough to run the example workflow.

Tried solutions

It is fine if I remove the amend command but it is not desired solution.

Example Workflow

my config 


name: Release plz 

on:
  pull_request:

jobs:
  print_commit_name:
    runs-on: ubuntu-latest

    permissions:
      # Give the default GITHUB_TOKEN write permission to commit and push the changed files back to the repository.
      contents: write

    if: startsWith(github.head_ref, 'release_')
    steps:
    - uses: actions/checkout@v3
      with:
        ref: ${{ github.head_ref }}
    - name: Create new file 
      run: echo '\n// New commit' > src/main.rs 
    - uses: stefanzweifel/git-auto-commit-action@v4
      with:
        commit_options: '--amend'
        push_options: '--force'

Relevant log output

No response

@jawoznia jawoznia added the bug Something isn't working label Jul 27, 2023
@stefanzweifel
Copy link
Owner

Howdy

Using --amend can be dangerous. I thought I had a section about this in the README, but there's only this section about using it in combination with --no-edit.

The problem lies in how actions/checkout checks out a repository. By default, only the last commit (1 commit) is checked out / fetched and not the entire repo history.

Another user ran into a similar issue in #159 (comment).

To solve this, add fetch-depth: 2 and skip_fetch: true to your job.

    - uses: actions/checkout@v3
      with:
        ref: ${{ github.head_ref }}
+       fetch-depth: 2


    - uses: stefanzweifel/git-auto-commit-action@v4
      with:
        commit_options: '--amend'
        push_options: '--force'
+       skip_fetch: true

fetch-depth: 2 to fetch more than just 1 single commit and not destroy the local commit history.

skip_fetch: true to disable an internal feature of git-auto-commit, where we run git fetch just before we try to run git checkout -B.

Let me know if this works or if you still run into the issue.

@jawoznia
Copy link
Author

Thanks for a quick response and great explanation. It works now.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
Development

No branches or pull requests

2 participants