Skip to content

:octocat: Github action to retrieve all (added, copied, modified, deleted, renamed, type changed, unmerged, unknown) files with support for push and pull request events.

License

Notifications You must be signed in to change notification settings

talva-tr/changed-files

 
 

Repository files navigation

CI Update release version. Codacy Badge Public workflows that use this action.

Ubuntu Mac OS Windows

All Contributors

changed-files

Retrieve all changed files relative to the default branch (pull_request* based events) or a previous commit (push based event) returning the absolute path to all changed files from the project root.

Features

  • Fast execution (0-2 seconds on average).
  • Easy to debug.
  • Boolean output indicating that certain files have been modified.
  • Multiple repository support.
  • List all files that have changed.
    • Between the current pull request branch and the default branch.
    • Between the last commit and the current pushed change.
  • Restrict change detection to a subset of files.
    • Report on files that have at least one change.
    • Regex pattern matching on a subset of files.

Usage

NOTE: ⚠️

  • IMPORTANT: For push events you need to include fetch-depth: 0 OR fetch-depth: 2 depending on your use case.
  • When using persist-credentials: false with actions/checkout@v2 you'll need to specify a token using the token input.
name: CI

on:
  push:
    branches:
      - main
  pull_request:
    branches:
      - main

jobs:
  build:
    runs-on: ubuntu-latest  # windows-latest | macos-latest
    name: Test changed-files
    steps:
      - uses: actions/checkout@v2
        with:
          fetch-depth: 0  # OR "2" -> To retrieve the preceding commit.

      - name: Get changed files
        id: changed-files
        uses: tj-actions/changed-files@v10

      - name: List all modified files
        run: |
          for file in "${{ steps.changed-files.outputs.all_modified_files }}"; do
            echo "$file was modified"
          done

Outputs

Acronym Meaning
A Added
C Copied
M Modified
D Deleted
R Renamed
T Type changed
U Unmerged
X Unknown
Output type example description
any_changed string true OR false Returns true when any
of the filenames provided using
the files input has changed.
i.e. using a combination of all added,
copied, modified and renamed files (ACMR)
only_changed string true OR false Returns true when only
files provided using
the files input have changed. (ACMR)
other_changed_files string 'new.txt path/to/file.png ...' Select all other changed files
not listed in the files input
i.e. a combination of all added,
copied and modified files (ACMR)
any_deleted string true OR false Returns true when any
of the filenames provided using
the files input has been deleted. (D)
only_deleted string true OR false Returns true when only
files provided using
the files input has been deleted. (D)
other_deleted_files string 'new.txt path/to/file.png ...' Select all other deleted files
not listed in the files input
i.e. a combination of all deleted files (D)
all_modified_files string 'new.txt path/to/file.png ...' Select all modified files
i.e. a combination of all added,
copied, modified and renamed files (ACMR)
all_changed_and_modified_files string 'new.txt path/to/file.png ...' Select all changed
and modified files
i.e. a combination of (ACMRDTUX)
added_files string 'new.txt path/to/file.png ...' Select only files that are Added (A)
copied_files string 'new.txt path/to/file.png ...' Select only files that are Copied (C)
deleted_files string 'new.txt path/to/file.png ...' Select only files that are Deleted (D)
modified_files string 'new.txt path/to/file.png ...' Select only files that are Modified (M)
renamed_files string 'new.txt path/to/file.png ...' Select only files that are Renamed (R)
type_changed_files string 'new.txt path/to/file.png ...' Select only files that have their file type changed (T)
unmerged_files string 'new.txt path/to/file.png ...' Select only files that are Unmerged (U)
unknown_files string 'new.txt path/to/file.png ...' Select only files that are Unknown (X)

Inputs

Input type required default description
token string false ${{ github.token }} GITHUB_TOKEN
or a repo scoped
Personal Access Token
separator string true ' ' Output string separator
files string OR string[] false Check for changes
using only these
list of file(s)
(Defaults to the
entire repo)
base_sha string false Specify a different
base commit SHA
used for
comparing changes
sha string true ${{ github.sha }} Specify a different
commit SHA
used for
comparing changes
files_from_source_file string false Source file
used to populate
the files input
path string false Relative path under
GITHUB_WORKSPACE
to the repository

Example

...
    steps:
      - uses: actions/checkout@v2

      - name: Get changed files using defaults
        id: changed-files
        uses: tj-actions/changed-files@v10

      - name: Get changed files using a comma separator
        id: changed-files-comma
        uses: tj-actions/changed-files@v10
        with:
          separator: ","

      - name: List all added files
        run: |
          for file in "${{ steps.changed-files.outputs.added_files }}"; do
            echo "$file was added"
          done

      - name: Run step when a file changes
        if: contains(steps.changed-files.outputs.modified_files, 'my-file.txt')
        run: |
          echo "Your file my-file.txt has been modified."

      - name: Run step when a file has been deleted
        if: contains(steps.changed-files.outputs.deleted_files, 'test.txt')
        run: |
          echo "Your test.txt has been deleted."

      - name: Get specific changed files
        id: changed-files-specific
        uses: tj-actions/changed-files@v10
        with:
          files: |
            my-file.txt
            test.txt
            new.txt
            test_directory
            \.sh$
            .(png|jpeg)$
            .(sql|py)$
            ^(mynewfile|custom)

      - name: Run step if any of the listed files above change
        if: steps.changed-files-specific.outputs.any_changed == 'true'
        run: |
          echo "One or more files listed above has changed."

      - name: Run step if only the files listed above change
        if: steps.changed-files-specific.outputs.only_changed == 'true'
        run: |
          echo "Only files listed above have changed."

      - name: Run step if any of the listed files above is deleted
        if: steps.changed-files.outputs.any_deleted == "true"
        run: |
          for file in "${{ steps.changed-files.outputs.deleted_files }}"; do
            echo "$file was deleted"
          done

      - name: Run step if all listed files above have been deleted
        if: steps.changed-files.outputs.only_deleted == "true"
        run: |
          for file in "${{ steps.changed-files.outputs.deleted_files }}"; do
            echo "$file was deleted"
          done

      - name: Use a source file or list of file(s) to populate to files input.
        id: changed-files-specific-source-file
        uses: tj-actions/changed-files@v10
        with:
          files_from_source_file: |
            test/changed-files-list.txt

      - name: Use a source file or list of file(s) to populate to files input and optionally specify more files.
        id: changed-files-specific-source-file-and-specify-files
        uses: tj-actions/changed-files@v10
        with:
          files_from_source_file: |
            test/changed-files-list.txt
          files: |
            test.txt

      - name: Use a different commit SHA
        id: changed-files-custom-sha
        uses: tj-actions/changed-files@v10
        with:
          sha: ${{ github.event.pull_request.head.sha }}

      - name: Use a different base SHA
        id: changed-files-custom-base-sha
        uses: tj-actions/changed-files@v10
        with:
          base_sha: "2096ed0"
          
      - name: Checkout into dir1
        uses: actions/checkout@v2
        with:
          fetch-depth: 0
          path: dir1

      - name: Run changed-files with defaults on the dir1
        id: changed-files-for-dir1
        uses: tj-actions/changed-files@v10
        with:
          path: dir1

      - name: List all added files in dir1
        run: |
          for file in "${{ steps.changed-files-for-dir1.outputs.added_files }}"; do
            echo "$file was added"
          done

Running pre-commit on all modified files

...
    steps:
      - uses: actions/checkout@v2
        with:
          fetch-depth: 0

      - name: Get changed files
        id: changed-files
        uses: tj-actions/changed-files@v10

      - name: Pre-commit
        uses: pre-commit/action@v2.0.0
        with:
          extra_args: -v --hook-stage push --files ${{ steps.changed-files.outputs.all_modified_files }}
          token: ${{ secrets.github_token }}

Screen Shot 2021-07-06 at 2 50 23 PM

Screen Shot 2021-07-17 at 10 52 48 AM

If you feel generous and want to show some extra appreciation:

Support me with a ⭐

Buy me a coffee

Credits

This package was created with Cookiecutter.

Report Bugs

Report bugs at https://github.com/tj-actions/changed-files/issues.

If you are reporting a bug, please include:

  • Your operating system name and version.
  • Any details about your workflow that might be helpful in troubleshooting.
  • Detailed steps to reproduce the bug.

Contributors ✨

Thanks goes to these wonderful people (emoji key):


Josh Soref

📖

Nick Landers

💻

Krasimir Nikolov

💻 📖

Ivan Pizhenko

💻 📖

This project follows the all-contributors specification. Contributions of any kind welcome!

About

:octocat: Github action to retrieve all (added, copied, modified, deleted, renamed, type changed, unmerged, unknown) files with support for push and pull request events.

Resources

License

Code of conduct

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Shell 100.0%