mirror of
https://github.com/home-assistant/iOS.git
synced 2026-02-08 06:11:05 -06:00
Bumps the dependencies group with 3 updates: [ruby/setup-ruby](https://github.com/ruby/setup-ruby), [actions/cache](https://github.com/actions/cache) and [docker/login-action](https://github.com/docker/login-action). Updates `ruby/setup-ruby` from 1.286.0 to 1.287.0 <details> <summary>Release notes</summary> <p><em>Sourced from <a href="https://github.com/ruby/setup-ruby/releases">ruby/setup-ruby's releases</a>.</em></p> <blockquote> <h2>v1.287.0</h2> <h2>What's Changed</h2> <ul> <li>Improve the mise.toml parser to conform to the TOML specification by <a href="https://github.com/pan93412"><code>@pan93412</code></a> in <a href="https://redirect.github.com/ruby/setup-ruby/pull/868">ruby/setup-ruby#868</a></li> </ul> <h2>New Contributors</h2> <ul> <li><a href="https://github.com/pan93412"><code>@pan93412</code></a> made their first contribution in <a href="https://redirect.github.com/ruby/setup-ruby/pull/868">ruby/setup-ruby#868</a></li> </ul> <p><strong>Full Changelog</strong>: <a href="https://github.com/ruby/setup-ruby/compare/v1.286.0...v1.287.0">https://github.com/ruby/setup-ruby/compare/v1.286.0...v1.287.0</a></p> </blockquote> </details> <details> <summary>Commits</summary> <ul> <li><a href="8d27f39a5e"><code>8d27f39</code></a> Improve the mise.toml parser to conform to the TOML specification</li> <li>See full diff in <a href="90be1154f9...8d27f39a5e">compare view</a></li> </ul> </details> <br /> Updates `actions/cache` from 5.0.2 to 5.0.3 <details> <summary>Release notes</summary> <p><em>Sourced from <a href="https://github.com/actions/cache/releases">actions/cache's releases</a>.</em></p> <blockquote> <h2>v5.0.3</h2> <h2>What's Changed</h2> <ul> <li>Bump <code>@actions/cache</code> to v5.0.5 (Resolves: <a href="https://github.com/actions/cache/security/dependabot/33">https://github.com/actions/cache/security/dependabot/33</a>)</li> <li>Bump <code>@actions/core</code> to v2.0.3</li> </ul> <p><strong>Full Changelog</strong>: <a href="https://github.com/actions/cache/compare/v5...v5.0.3">https://github.com/actions/cache/compare/v5...v5.0.3</a></p> </blockquote> </details> <details> <summary>Changelog</summary> <p><em>Sourced from <a href="https://github.com/actions/cache/blob/main/RELEASES.md">actions/cache's changelog</a>.</em></p> <blockquote> <h1>Releases</h1> <h2>How to prepare a release</h2> <blockquote> <p>[!NOTE]<br /> Relevant for maintainers with write access only.</p> </blockquote> <ol> <li>Switch to a new branch from <code>main</code>.</li> <li>Run <code>npm test</code> to ensure all tests are passing.</li> <li>Update the version in <a href="https://github.com/actions/cache/blob/main/package.json"><code>https://github.com/actions/cache/blob/main/package.json</code></a>.</li> <li>Run <code>npm run build</code> to update the compiled files.</li> <li>Update this <a href="https://github.com/actions/cache/blob/main/RELEASES.md"><code>https://github.com/actions/cache/blob/main/RELEASES.md</code></a> with the new version and changes in the <code>## Changelog</code> section.</li> <li>Run <code>licensed cache</code> to update the license report.</li> <li>Run <code>licensed status</code> and resolve any warnings by updating the <a href="https://github.com/actions/cache/blob/main/.licensed.yml"><code>https://github.com/actions/cache/blob/main/.licensed.yml</code></a> file with the exceptions.</li> <li>Commit your changes and push your branch upstream.</li> <li>Open a pull request against <code>main</code> and get it reviewed and merged.</li> <li>Draft a new release <a href="https://github.com/actions/cache/releases">https://github.com/actions/cache/releases</a> use the same version number used in <code>package.json</code> <ol> <li>Create a new tag with the version number.</li> <li>Auto generate release notes and update them to match the changes you made in <code>RELEASES.md</code>.</li> <li>Toggle the set as the latest release option.</li> <li>Publish the release.</li> </ol> </li> <li>Navigate to <a href="https://github.com/actions/cache/actions/workflows/release-new-action-version.yml">https://github.com/actions/cache/actions/workflows/release-new-action-version.yml</a> <ol> <li>There should be a workflow run queued with the same version number.</li> <li>Approve the run to publish the new version and update the major tags for this action.</li> </ol> </li> </ol> <h2>Changelog</h2> <h3>5.0.3</h3> <ul> <li>Bump <code>@actions/cache</code> to v5.0.5 (Resolves: <a href="https://github.com/actions/cache/security/dependabot/33">https://github.com/actions/cache/security/dependabot/33</a>)</li> <li>Bump <code>@actions/core</code> to v2.0.3</li> </ul> <h3>5.0.2</h3> <ul> <li>Bump <code>@actions/cache</code> to v5.0.3 <a href="https://redirect.github.com/actions/cache/pull/1692">#1692</a></li> </ul> <h3>5.0.1</h3> <ul> <li>Update <code>@azure/storage-blob</code> to <code>^12.29.1</code> via <code>@actions/cache@5.0.1</code> <a href="https://redirect.github.com/actions/cache/pull/1685">#1685</a></li> </ul> <h3>5.0.0</h3> <blockquote> <p>[!IMPORTANT] <code>actions/cache@v5</code> runs on the Node.js 24 runtime and requires a minimum Actions Runner version of <code>2.327.1</code>. If you are using self-hosted runners, ensure they are updated before upgrading.</p> </blockquote> <h3>4.3.0</h3> <ul> <li>Bump <code>@actions/cache</code> to <a href="https://redirect.github.com/actions/toolkit/pull/2132">v4.1.0</a></li> </ul> <!-- raw HTML omitted --> </blockquote> <p>... (truncated)</p> </details> <details> <summary>Commits</summary> <ul> <li><a href="cdf6c1fa76"><code>cdf6c1f</code></a> Merge pull request <a href="https://redirect.github.com/actions/cache/issues/1695">#1695</a> from actions/Link-/prepare-5.0.3</li> <li><a href="a1bee22673"><code>a1bee22</code></a> Add review for the <code>@actions/http-client</code> license</li> <li><a href="46957638dc"><code>4695763</code></a> Add licensed output</li> <li><a href="dc73bb9f7b"><code>dc73bb9</code></a> Upgrade dependencies and address security warnings</li> <li><a href="345d5c2f76"><code>345d5c2</code></a> Add 5.0.3 builds</li> <li>See full diff in <a href="8b402f58fb...cdf6c1fa76">compare view</a></li> </ul> </details> <br /> Updates `docker/login-action` from 3.6.0 to 3.7.0 <details> <summary>Release notes</summary> <p><em>Sourced from <a href="https://github.com/docker/login-action/releases">docker/login-action's releases</a>.</em></p> <blockquote> <h2>v3.7.0</h2> <ul> <li>Add <code>scope</code> input to set scopes for the authentication token by <a href="https://github.com/crazy-max"><code>@crazy-max</code></a> in <a href="https://redirect.github.com/docker/login-action/pull/912">docker/login-action#912</a></li> <li>Add support for AWS European Sovereign Cloud ECR by <a href="https://github.com/dphi"><code>@dphi</code></a> in <a href="https://redirect.github.com/docker/login-action/pull/914">docker/login-action#914</a></li> <li>Ensure passwords are redacted with <code>registry-auth</code> input by <a href="https://github.com/crazy-max"><code>@crazy-max</code></a> in <a href="https://redirect.github.com/docker/login-action/pull/911">docker/login-action#911</a></li> <li>build(deps): bump lodash from 4.17.21 to 4.17.23 in <a href="https://redirect.github.com/docker/login-action/pull/915">docker/login-action#915</a></li> </ul> <p><strong>Full Changelog</strong>: <a href="https://github.com/docker/login-action/compare/v3.6.0...v3.7.0">https://github.com/docker/login-action/compare/v3.6.0...v3.7.0</a></p> </blockquote> </details> <details> <summary>Commits</summary> <ul> <li><a href="c94ce9fb46"><code>c94ce9f</code></a> Merge pull request <a href="https://redirect.github.com/docker/login-action/issues/915">#915</a> from docker/dependabot/npm_and_yarn/lodash-4.17.23</li> <li><a href="8339c958ce"><code>8339c95</code></a> Merge pull request <a href="https://redirect.github.com/docker/login-action/issues/912">#912</a> from docker/scope</li> <li><a href="c83e9320c8"><code>c83e932</code></a> build(deps): bump lodash from 4.17.21 to 4.17.23</li> <li><a href="b268aa57e3"><code>b268aa5</code></a> chore: update generated content</li> <li><a href="a603229278"><code>a603229</code></a> documentation for scope input</li> <li><a href="7567f92a74"><code>7567f92</code></a> Add scope input to set scopes for the authentication token</li> <li><a href="0567fa5ae8"><code>0567fa5</code></a> Merge pull request <a href="https://redirect.github.com/docker/login-action/issues/914">#914</a> from dphi/add-support-for-amazonaws.eu</li> <li><a href="f6ef577545"><code>f6ef577</code></a> feat: add support for AWS European Sovereign Cloud ECR registries</li> <li><a href="916386b000"><code>916386b</code></a> Merge pull request <a href="https://redirect.github.com/docker/login-action/issues/911">#911</a> from crazy-max/ensure-redact</li> <li><a href="5b3f94a294"><code>5b3f94a</code></a> chore: update generated content</li> <li>Additional commits viewable in <a href="5e57cd1181...c94ce9fb46">compare view</a></li> </ul> </details> <br /> Dependabot will resolve any conflicts with this PR as long as you don't alter it yourself. You can also trigger a rebase manually by commenting `@dependabot rebase`. [//]: # (dependabot-automerge-start) [//]: # (dependabot-automerge-end) --- <details> <summary>Dependabot commands and options</summary> <br /> You can trigger Dependabot actions by commenting on this PR: - `@dependabot rebase` will rebase this PR - `@dependabot recreate` will recreate this PR, overwriting any edits that have been made to it - `@dependabot merge` will merge this PR after your CI passes on it - `@dependabot squash and merge` will squash and merge this PR after your CI passes on it - `@dependabot cancel merge` will cancel a previously requested merge and block automerging - `@dependabot reopen` will reopen this PR if it is closed - `@dependabot close` will close this PR and stop Dependabot recreating it. You can achieve the same result by closing it manually - `@dependabot show <dependency name> ignore conditions` will show all of the ignore conditions of the specified dependency - `@dependabot ignore <dependency name> major version` will close this group update PR and stop Dependabot creating any more for the specific dependency's major version (unless you unignore this specific dependency's major version or upgrade to it yourself) - `@dependabot ignore <dependency name> minor version` will close this group update PR and stop Dependabot creating any more for the specific dependency's minor version (unless you unignore this specific dependency's minor version or upgrade to it yourself) - `@dependabot ignore <dependency name>` will close this group update PR and stop Dependabot creating any more for the specific dependency (unless you unignore this specific dependency or upgrade to it yourself) - `@dependabot unignore <dependency name>` will remove all of the ignore conditions of the specified dependency - `@dependabot unignore <dependency name> <ignore condition>` will remove the ignore condition of the specified dependency and ignore conditions </details> Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
253 lines
9.0 KiB
YAML
253 lines
9.0 KiB
YAML
name: CI
|
|
|
|
permissions:
|
|
contents: read
|
|
pull-requests: write
|
|
|
|
on:
|
|
pull_request:
|
|
push:
|
|
branches:
|
|
- main
|
|
|
|
env:
|
|
DEVELOPER_DIR: /Applications/Xcode_26.2.app/Contents/Developer
|
|
FASTLANE_SKIP_UPDATE_CHECK: true
|
|
FASTLANE_XCODE_LIST_TIMEOUT: 80
|
|
FASTLANE_XCODEBUILD_SETTINGS_TIMEOUT: 80
|
|
HOMEBREW_NO_INSTALL_CLEANUP: TRUE
|
|
BUNDLE_PATH: vendor/bundle
|
|
|
|
concurrency:
|
|
group: ci-${{ github.ref }}
|
|
cancel-in-progress: true
|
|
|
|
jobs:
|
|
lint:
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
|
|
- uses: ruby/setup-ruby@8d27f39a5e7ad39aebbcbd1324f7af020229645c # v1.287.0
|
|
with:
|
|
ruby-version: "3.1"
|
|
bundler-cache: true
|
|
- name: YamlLint
|
|
run: yamllint --strict --format github .
|
|
- name: RuboCop
|
|
run: bundle exec rubocop --format github
|
|
- name: SwiftLint
|
|
run: |
|
|
docker run --rm -v `pwd`:`pwd` -w `pwd` \
|
|
ghcr.io/realm/swiftlint:0.54.0 \
|
|
swiftlint lint --strict --config .swiftlint.yml --reporter github-actions-logging
|
|
- name: SwiftFormat
|
|
run: |
|
|
docker run --rm -v `pwd`:`pwd` -w `pwd` \
|
|
ghcr.io/nicklockwood/swiftformat:0.53.1 \
|
|
--lint --config .swiftformat .
|
|
|
|
check-swiftlint-disables:
|
|
needs: lint
|
|
if: github.event_name == 'pull_request'
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
|
|
|
|
- name: Scan for `swiftlint:disable` in PR diff
|
|
id: scan
|
|
continue-on-error: false
|
|
run: |
|
|
git fetch origin main:refs/remotes/origin/main
|
|
DISABLE_LINES=$(git diff origin/main -- '*.swift' | grep -E '^\+.*// swiftlint:disable' || true)
|
|
echo "disable_lines<<EOF" >> $GITHUB_OUTPUT
|
|
echo "$DISABLE_LINES" >> $GITHUB_OUTPUT
|
|
echo "EOF" >> $GITHUB_OUTPUT
|
|
|
|
- name: Comment on PR if `swiftlint:disable` is found
|
|
if: steps.scan.outputs.disable_lines != ''
|
|
uses: marocchino/sticky-pull-request-comment@773744901bac0e8cbb5a0dc842800d45e9b2b405 # v2.9.4
|
|
with:
|
|
header: swiftlint-disable-check
|
|
message: |
|
|
⚠️ **SwiftLint disabled in this PR**
|
|
|
|
The following added lines contain `// swiftlint:disable`. Please verify this is necessary.
|
|
|
|
check-unused-strings:
|
|
needs: lint
|
|
if: github.event_name == 'pull_request'
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
|
|
|
|
- name: Set up Python
|
|
uses: actions/setup-python@a309ff8b426b58ec0e2a45f0f869d46889d02405 # v5.3.0
|
|
with:
|
|
python-version: '3.x'
|
|
|
|
- name: Detect unused L10n strings
|
|
id: detect
|
|
continue-on-error: true
|
|
run: |
|
|
OUTPUT=$(python3 Tools/detect_unused_strings.py 2>&1 || true)
|
|
echo "output<<EOF" >> $GITHUB_OUTPUT
|
|
echo "$OUTPUT" >> $GITHUB_OUTPUT
|
|
echo "EOF" >> $GITHUB_OUTPUT
|
|
|
|
# Check if any unused strings were found
|
|
if echo "$OUTPUT" | grep -q "Total unused:"; then
|
|
COUNT=$(echo "$OUTPUT" | grep "Total unused:" | grep -oE '[0-9]+')
|
|
echo "has_unused=true" >> $GITHUB_OUTPUT
|
|
echo "count=$COUNT" >> $GITHUB_OUTPUT
|
|
else
|
|
echo "has_unused=false" >> $GITHUB_OUTPUT
|
|
echo "count=0" >> $GITHUB_OUTPUT
|
|
fi
|
|
|
|
- name: Comment on PR if unused strings are found
|
|
if: steps.detect.outputs.has_unused == 'true'
|
|
uses: marocchino/sticky-pull-request-comment@773744901bac0e8cbb5a0dc842800d45e9b2b405 # v2.9.4
|
|
with:
|
|
header: unused-strings-check
|
|
message: |
|
|
⚠️ **Unused L10n strings detected**
|
|
|
|
Found **${{ steps.detect.outputs.count }}** unused localization strings in the codebase.
|
|
|
|
<details>
|
|
<summary>Click to see details</summary>
|
|
|
|
```
|
|
${{ steps.detect.outputs.output }}
|
|
```
|
|
|
|
</details>
|
|
|
|
To clean up these strings, manually remove them from the `Localizable.strings` files
|
|
and regenerate `Strings.swift` using SwiftGen.
|
|
|
|
test:
|
|
needs: check-swiftlint-disables
|
|
runs-on: macos-15
|
|
timeout-minutes: 45
|
|
steps:
|
|
- uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
|
|
|
|
- uses: actions/cache@cdf6c1fa76f9f475f3d7449005a359c84ca0f306 # v5.0.3
|
|
name: "Cache: Pods"
|
|
id: cache_pods
|
|
with:
|
|
path: |
|
|
Pods
|
|
Tools/MaterialDesignIcons.ttf
|
|
Tools/MaterialDesignIcons.json
|
|
key: >-
|
|
${{ runner.os }}-pods-${{ env.DEVELOPER_DIR }}-
|
|
${{ hashFiles('**/Gemfile.lock', '**/Podfile.lock', 'Tools/BuildMaterialDesignIconsFont.sh') }}
|
|
|
|
- uses: actions/cache@cdf6c1fa76f9f475f3d7449005a359c84ca0f306 # v5.0.3
|
|
name: "Cache: Gems"
|
|
id: cache_gems
|
|
with:
|
|
path: vendor/bundle
|
|
key: >-
|
|
${{ runner.os }}-gems-${{ env.ImageVersion }}-${{ env.DEVELOPER_DIR }}-${{ hashFiles('**/Gemfile.lock') }}
|
|
|
|
- name: Install Brews
|
|
# right now, we don't need anything from brew for tests, so save some time
|
|
if: ${{ false }}
|
|
run: brew bundle
|
|
|
|
- name: Install Gems
|
|
if: steps.cache_gems.outputs.cache-hit != 'true'
|
|
run: bundle install --jobs 4 --retry 3
|
|
|
|
- name: Install Pods Release
|
|
if: steps.cache_pods.outputs.cache-hit != 'true'
|
|
run: bundle exec pod install --repo-update
|
|
|
|
- name: Run tests
|
|
run: bundle exec fastlane test
|
|
|
|
- uses: codecov/codecov-action@671740ac38dd9b0130fbe1cec585b89eea48d3de # v5.5.2
|
|
name: "Upload Code Coverage"
|
|
with:
|
|
xcode: true
|
|
xcode_archive_path: fastlane/test_output/Tests-Unit.xcresult
|
|
|
|
- uses: actions/upload-artifact@b7c566a772e6b6bfb58ed0dc250532a479d7789f # v6.0.0
|
|
name: "Upload Test Logs"
|
|
if: ${{ always() }}
|
|
with:
|
|
name: test-logs
|
|
path: |
|
|
~/Library/Logs/DiagnosticReports
|
|
~/Library/Developer/Xcode/DerivedData/HomeAssistant-*/Logs/Test
|
|
~/Library/Logs/scan
|
|
|
|
- uses: actions/upload-artifact@b7c566a772e6b6bfb58ed0dc250532a479d7789f # v6.0.0
|
|
name: "Upload Simulator App"
|
|
with:
|
|
name: ios-simulator
|
|
path: ~/Library/Developer/Xcode/DerivedData/HomeAssistant-*/Build/Products/Debug-iphonesimulator/*.app
|
|
|
|
size:
|
|
needs: check-swiftlint-disables
|
|
if: |
|
|
github.event_name == 'pull_request' &&
|
|
github.event.pull_request.head.repo.full_name == 'home-assistant/iOS'
|
|
runs-on: macos-15
|
|
timeout-minutes: 45
|
|
steps:
|
|
- uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
|
|
- uses: actions/cache@cdf6c1fa76f9f475f3d7449005a359c84ca0f306 # v4.6.2
|
|
name: "Cache: Pods"
|
|
id: cache_pods
|
|
with:
|
|
path: |
|
|
Pods
|
|
Tools/MaterialDesignIcons.ttf
|
|
Tools/MaterialDesignIcons.json
|
|
key: >-
|
|
${{ runner.os }}-pods-${{ env.DEVELOPER_DIR }}-
|
|
${{ hashFiles('**/Gemfile.lock', '**/Podfile.lock', 'Tools/BuildMaterialDesignIconsFont.sh') }}
|
|
|
|
- uses: actions/cache@cdf6c1fa76f9f475f3d7449005a359c84ca0f306 # v5.0.3
|
|
name: "Cache: Gems"
|
|
id: cache_gems
|
|
with:
|
|
path: vendor/bundle
|
|
key: >-
|
|
${{ runner.os }}-gems-${{ env.ImageVersion }}-${{ env.DEVELOPER_DIR }}-${{ hashFiles('**/Gemfile.lock') }}
|
|
|
|
- name: Install Brews
|
|
# right now, we don't need anything from brew for sizing, so save some time
|
|
if: ${{ false }}
|
|
run: brew bundle
|
|
|
|
- name: Install Gems
|
|
if: steps.cache_gems.outputs.cache-hit != 'true'
|
|
run: bundle install --jobs 4 --retry 3
|
|
|
|
- name: Install Pods Release
|
|
if: steps.cache_pods.outputs.cache-hit != 'true'
|
|
run: bundle exec pod install --repo-update
|
|
|
|
- name: Build app
|
|
run: bundle exec fastlane ios size
|
|
env:
|
|
P12_KEY_DISTRIBUTION: ${{ secrets.P12_KEY_DISTRIBUTION }}
|
|
P12_VALUE_DISTRIBUTION: ${{ secrets.P12_VALUE_DISTRIBUTION }}
|
|
P12_KEY_MAC_DEVELOPER_ID: ${{ secrets.P12_KEY_MAC_DEVELOPER_ID }}
|
|
P12_KEY_MAC_DEVELOPER_INSTALLER: ${{ secrets.P12_KEY_MAC_DEVELOPER_INSTALLER }}
|
|
P12_VALUE_MAC_DEVELOPER_ID: ${{ secrets.P12_VALUE_MAC_DEVELOPER_ID }}
|
|
P12_VALUE_MAC_DEVELOPER_INSTALLER: ${{ secrets.P12_VALUE_MAC_DEVELOPER_INSTALLER }}
|
|
EMERGE_API_TOKEN: ${{ secrets.EMERGE_API_TOKEN }}
|
|
EMERGE_REPO_NAME: ${{ github.repository }}
|
|
EMERGE_PR_NUMBER: ${{ github.event.number }}
|
|
EMERGE_SHA: ${{ github.event.pull_request.head.sha }}
|
|
EMERGE_BASE_SHA: ${{ github.event.pull_request.base.sha }}
|
|
HOMEASSISTANT_APP_STORE_CONNECT_PASSWORD: ${{ secrets.HOMEASSISTANT_APP_STORE_CONNECT_PASSWORD }}
|
|
HOMEASSISTANT_APPLE_ID: ${{ secrets.HOMEASSISTANT_APPLE_ID }}
|
|
HOMEASSISTANT_FASTLANE_SESSION: ${{ secrets.HOMEASSISTANT_FASTLANE_SESSION }}
|