Compare commits
7 Commits
8a8de87d85
...
fix-toast
Author | SHA1 | Date | |
---|---|---|---|
a602f7adf2 | |||
cf6ef51edf | |||
0b7f832573 | |||
22c966bf16 | |||
bdf2bb8b31 | |||
ceae91206d | |||
11c0e744dc |
50
.gitea/workflows/on_called_build.yml
Normal file
50
.gitea/workflows/on_called_build.yml
Normal file
@ -0,0 +1,50 @@
|
|||||||
|
name: Build
|
||||||
|
on:
|
||||||
|
workflow_call:
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
BuildAndTestAndCoverage:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v4
|
||||||
|
with:
|
||||||
|
fetch-depth: 0
|
||||||
|
- name: "Check android app changes"
|
||||||
|
id: check-android-changes
|
||||||
|
uses: tj-actions/changed-files@v45
|
||||||
|
with:
|
||||||
|
files: |
|
||||||
|
androidApp/src/**
|
||||||
|
shared/src/commonMain/**
|
||||||
|
shared/src/androidMain/**
|
||||||
|
shared/src/commonTest/**
|
||||||
|
- name: Fetch tags
|
||||||
|
if: steps.check-android-changes.outputs.any_modified == 'true'
|
||||||
|
run: git fetch --tags -p
|
||||||
|
- uses: actions/setup-java@v4
|
||||||
|
if: steps.check-android-changes.outputs.any_modified == 'true'
|
||||||
|
with:
|
||||||
|
distribution: 'temurin'
|
||||||
|
java-version: '17'
|
||||||
|
- uses: gradle/actions/setup-gradle@v3
|
||||||
|
if: steps.check-android-changes.outputs.any_modified == 'true'
|
||||||
|
- uses: android-actions/setup-android@v3
|
||||||
|
if: steps.check-android-changes.outputs.any_modified == 'true'
|
||||||
|
- name: Configure gradle...
|
||||||
|
if: steps.check-android-changes.outputs.any_modified == 'true'
|
||||||
|
run: mkdir -p ~/.gradle && echo "org.gradle.daemon=false\nignoreGitVersion=true" >> ~/.gradle/gradle.properties
|
||||||
|
- name: Build and test
|
||||||
|
if: steps.check-android-changes.outputs.any_modified == 'true'
|
||||||
|
run: ./gradlew build -x testReleaseUnitTest -x testDebugUnitTest -x testGithubConfigReleaseUnitTest -x testGithubConfigDebugUnitTest
|
||||||
|
- name: coverage
|
||||||
|
if: steps.check-android-changes.outputs.any_modified == 'true'
|
||||||
|
run: |
|
||||||
|
./gradlew :koverHtmlReport
|
||||||
|
- uses: actions/upload-artifact@v3
|
||||||
|
if: steps.check-android-changes.outputs.any_modified == 'true'
|
||||||
|
with:
|
||||||
|
name: coverage
|
||||||
|
path: build/reports/kover/html
|
||||||
|
retention-days: 1
|
||||||
|
overwrite: true
|
||||||
|
include-hidden-files: true
|
@ -1,4 +1,4 @@
|
|||||||
name: Create tag
|
name: Realease
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
branches:
|
branches:
|
||||||
@ -7,51 +7,7 @@ on:
|
|||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
build:
|
build:
|
||||||
runs-on: ubuntu-latest
|
uses: ./.gitea/workflows/on_called_build.yml
|
||||||
steps:
|
|
||||||
- name: Check out repository code
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
with:
|
|
||||||
fetch-depth: 0
|
|
||||||
- name: "Check android app changes"
|
|
||||||
id: check-android-changes
|
|
||||||
uses: tj-actions/changed-files@v45
|
|
||||||
with:
|
|
||||||
files: |
|
|
||||||
androidApp/src/**
|
|
||||||
shared/src/commonMain/**
|
|
||||||
shared/src/androidMain/**
|
|
||||||
shared/src/commonTest/**
|
|
||||||
- name: Fetch tags
|
|
||||||
if: ${{ steps.check-android-changes.outputs.any_modified == 'true' }}
|
|
||||||
run: git fetch --tags -p
|
|
||||||
- uses: actions/setup-java@v4
|
|
||||||
if: ${{ steps.check-android-changes.outputs.any_modified == 'true' }}
|
|
||||||
with:
|
|
||||||
distribution: 'temurin'
|
|
||||||
java-version: '17'
|
|
||||||
- uses: gradle/actions/setup-gradle@v3
|
|
||||||
if: ${{ steps.check-android-changes.outputs.any_modified == 'true' }}
|
|
||||||
- uses: android-actions/setup-android@v3
|
|
||||||
if: ${{ steps.check-android-changes.outputs.any_modified == 'true' }}
|
|
||||||
- name: Configure gradle...
|
|
||||||
if: ${{ steps.check-android-changes.outputs.any_modified == 'true' }}
|
|
||||||
run: mkdir -p ~/.gradle && echo "org.gradle.daemon=false\nignoreGitVersion=true" >> ~/.gradle/gradle.properties
|
|
||||||
- name: Build and test
|
|
||||||
if: ${{ steps.check-android-changes.outputs.any_modified == 'true' }}
|
|
||||||
run: ./gradlew build -x testReleaseUnitTest -x testDebugUnitTest -x testGithubConfigReleaseUnitTest -x testGithubConfigDebugUnitTest
|
|
||||||
- name: coverage
|
|
||||||
if: ${{ steps.check-android-changes.outputs.any_modified == 'true' }}
|
|
||||||
run: |
|
|
||||||
./gradlew :koverHtmlReport
|
|
||||||
- uses: actions/upload-artifact@v3
|
|
||||||
if: ${{ steps.check-android-changes.outputs.any_modified == 'true' }}
|
|
||||||
with:
|
|
||||||
name: coverage
|
|
||||||
path: build/reports/kover/html
|
|
||||||
retention-days: 1
|
|
||||||
overwrite: true
|
|
||||||
include-hidden-files: true
|
|
||||||
createTagAndChangelog:
|
createTagAndChangelog:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
needs: build
|
needs: build
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
name: Check PR code
|
name: PR
|
||||||
on:
|
on:
|
||||||
pull_request:
|
pull_request:
|
||||||
branches:
|
branches:
|
||||||
@ -22,6 +22,13 @@ jobs:
|
|||||||
run: ktlint 'shared/**/*.kt' 'androidApp/**/*.kt' '!shared/build'
|
run: ktlint 'shared/**/*.kt' 'androidApp/**/*.kt' '!shared/build'
|
||||||
- name: Detecting...
|
- name: Detecting...
|
||||||
run: ./detekt-cli-1.23.7/bin/detekt-cli -c detekt.yml --excludes '**/shared/build/**/*.kt'
|
run: ./detekt-cli-1.23.7/bin/detekt-cli -c detekt.yml --excludes '**/shared/build/**/*.kt'
|
||||||
|
translations:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- name: Check out repository code
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
with:
|
||||||
|
fetch-depth: 0
|
||||||
- name: "Check translations changes"
|
- name: "Check translations changes"
|
||||||
id: check-translations-changes
|
id: check-translations-changes
|
||||||
uses: tj-actions/changed-files@v45
|
uses: tj-actions/changed-files@v45
|
||||||
@ -29,7 +36,7 @@ jobs:
|
|||||||
files: |
|
files: |
|
||||||
androidApp/src/main/res/values/strings.xml
|
androidApp/src/main/res/values/strings.xml
|
||||||
- name: upload translation sources
|
- name: upload translation sources
|
||||||
if: ${{ steps.check-translations-changes.outputs.any_modified == 'true' }}
|
if: steps.check-translations-changes.outputs.any_modified == 'true'
|
||||||
uses: crowdin/github-action@v2
|
uses: crowdin/github-action@v2
|
||||||
with:
|
with:
|
||||||
config: './.gitea/workflows/assets/crowdin.yml'
|
config: './.gitea/workflows/assets/crowdin.yml'
|
||||||
@ -42,10 +49,10 @@ jobs:
|
|||||||
CROWDIN_PROJECT_ID: ${{ secrets.CROWDIN_PROJECT_ID }}
|
CROWDIN_PROJECT_ID: ${{ secrets.CROWDIN_PROJECT_ID }}
|
||||||
CROWDIN_PERSONAL_TOKEN: ${{ secrets.CROWDIN_PERSONAL_TOKEN }}
|
CROWDIN_PERSONAL_TOKEN: ${{ secrets.CROWDIN_PERSONAL_TOKEN }}
|
||||||
- name: wait
|
- name: wait
|
||||||
if: ${{ steps.check-translations-changes.outputs.any_modified == 'true' }}
|
if: steps.check-translations-changes.outputs.any_modified == 'true'
|
||||||
run: sleep 10s
|
run: sleep 10s
|
||||||
- name: download translations
|
- name: download translations
|
||||||
if: ${{ steps.check-translations-changes.outputs.any_modified == 'true' }}
|
if: steps.check-translations-changes.outputs.any_modified == 'true'
|
||||||
uses: crowdin/github-action@v2
|
uses: crowdin/github-action@v2
|
||||||
with:
|
with:
|
||||||
config: './.gitea/workflows/assets/crowdin.yml'
|
config: './.gitea/workflows/assets/crowdin.yml'
|
||||||
@ -58,18 +65,18 @@ jobs:
|
|||||||
CROWDIN_PROJECT_ID: ${{ secrets.CROWDIN_PROJECT_ID }}
|
CROWDIN_PROJECT_ID: ${{ secrets.CROWDIN_PROJECT_ID }}
|
||||||
CROWDIN_PERSONAL_TOKEN: ${{ secrets.CROWDIN_PERSONAL_TOKEN }}
|
CROWDIN_PERSONAL_TOKEN: ${{ secrets.CROWDIN_PERSONAL_TOKEN }}
|
||||||
- name: Check for uncommitted changes
|
- name: Check for uncommitted changes
|
||||||
if: ${{ steps.check-translations-changes.outputs.any_modified == 'true' }}
|
if: steps.check-translations-changes.outputs.any_modified == 'true'
|
||||||
id: check-changes
|
id: check-changes
|
||||||
uses: mskri/check-uncommitted-changes-action@v1.0.1
|
uses: mskri/check-uncommitted-changes-action@v1.0.1
|
||||||
- name: Commit Changes
|
- name: Commit Changes
|
||||||
if: ${{ steps.check-translations-changes.outputs.any_modified == 'true' }} && ${{ steps.check-changes.outputs.changes != '' }}
|
if: steps.check-translations-changes.outputs.any_modified == 'true' && steps.check-changes.outputs.changes != ''
|
||||||
run: |
|
run: |
|
||||||
git config --global user.email aminecmi+giteadrone@pm.me
|
git config --global user.email aminecmi+giteadrone@pm.me
|
||||||
git config --global user.name giteadrone
|
git config --global user.name giteadrone
|
||||||
git add ./androidApp/src/main/res/*
|
git add ./androidApp/src/main/res/*
|
||||||
git commit -m "translation: translation files"
|
git commit -m "translation: translation files"
|
||||||
- name: Push changes
|
- name: Push changes
|
||||||
if: ${{ steps.check-translations-changes.outputs.any_modified == 'true' }} && ${{ steps.check-changes.outputs.changes != '' }}
|
if: steps.check-translations-changes.outputs.any_modified == 'true' && steps.check-changes.outputs.changes != ''
|
||||||
uses: appleboy/git-push-action@v1.0.0
|
uses: appleboy/git-push-action@v1.0.0
|
||||||
with:
|
with:
|
||||||
author_name: giteadrone
|
author_name: giteadrone
|
||||||
@ -77,87 +84,6 @@ jobs:
|
|||||||
remote: ${{ secrets.REMOTE_URL }}
|
remote: ${{ secrets.REMOTE_URL }}
|
||||||
ssh_key: ${{ secrets.PRIVATE_KEY }}
|
ssh_key: ${{ secrets.PRIVATE_KEY }}
|
||||||
branch: ${{ github.head_ref || github.ref_name }}
|
branch: ${{ github.head_ref || github.ref_name }}
|
||||||
- name: "Check android app changes"
|
build:
|
||||||
id: check-android-changes
|
needs: Lint
|
||||||
uses: tj-actions/changed-files@v45
|
uses: ./.gitea/workflows/on_called_build.yml
|
||||||
with:
|
|
||||||
files: |
|
|
||||||
androidApp/src/**
|
|
||||||
shared/src/commonMain/**
|
|
||||||
shared/src/androidMain/**
|
|
||||||
shared/src/commonTest/**
|
|
||||||
- name: Fetch tags
|
|
||||||
if: ${{ steps.check-android-changes.outputs.any_modified == 'true' }}
|
|
||||||
run: git fetch --tags -p
|
|
||||||
- uses: gradle/actions/setup-gradle@v3
|
|
||||||
if: ${{ steps.check-android-changes.outputs.any_modified == 'true' }}
|
|
||||||
- uses: android-actions/setup-android@v3
|
|
||||||
if: ${{ steps.check-android-changes.outputs.any_modified == 'true' }}
|
|
||||||
- name: Configure gradle...
|
|
||||||
if: ${{ steps.check-android-changes.outputs.any_modified == 'true' }}
|
|
||||||
run: mkdir -p ~/.gradle && echo "org.gradle.daemon=false\nignoreGitVersion=true" >> ~/.gradle/gradle.properties
|
|
||||||
- name: Change url until I find a better way to do it
|
|
||||||
if: ${{ steps.check-android-changes.outputs.any_modified == 'true' }}
|
|
||||||
run: |
|
|
||||||
sed -i "s/const DEFAULT_URL = \"http:\/\/10\.0\.2\.2\:8888\"/const DEFAULT_URL = \"http:\/\/172\.17\.0\.1\:8888\"/g" ./androidApp/src/androidTest/kotlin/bou/amine/apps/readerforselfossv2/android/CommonTests.kt
|
|
||||||
- name: Build and test
|
|
||||||
if: ${{ steps.check-android-changes.outputs.any_modified == 'true' }}
|
|
||||||
run: ./gradlew build -x testReleaseUnitTest -x testDebugUnitTest -x testGithubConfigReleaseUnitTest -x testGithubConfigDebugUnitTest
|
|
||||||
- name: coverage
|
|
||||||
if: ${{ steps.check-android-changes.outputs.any_modified == 'true' }}
|
|
||||||
run: |
|
|
||||||
./gradlew :koverHtmlReport
|
|
||||||
- uses: actions/upload-artifact@v3
|
|
||||||
if: ${{ steps.check-android-changes.outputs.any_modified == 'true' }}
|
|
||||||
with:
|
|
||||||
name: coverage
|
|
||||||
path: build/reports/kover/html
|
|
||||||
retention-days: 1
|
|
||||||
overwrite: true
|
|
||||||
include-hidden-files: true
|
|
||||||
- uses: KengoTODA/actions-setup-docker-compose@v1
|
|
||||||
if: ${{ steps.check-android-changes.outputs.any_modified == 'true' }}
|
|
||||||
with:
|
|
||||||
version: "2.23.3"
|
|
||||||
- name: run selfoss
|
|
||||||
if: ${{ steps.check-android-changes.outputs.any_modified == 'true' }}
|
|
||||||
run: |
|
|
||||||
docker compose -f .gitea/workflows/assets/docker-compose.yml up -d
|
|
||||||
- name: Tests
|
|
||||||
if: ${{ steps.check-android-changes.outputs.any_modified == 'true' }}
|
|
||||||
uses: reactivecircus/android-emulator-runner@v2
|
|
||||||
with:
|
|
||||||
api-level: 29
|
|
||||||
profile: pixel_2
|
|
||||||
script: |
|
|
||||||
./gradlew androidApp:clearScreenshotsTask || true
|
|
||||||
./gradlew androidApp:createScreenshotDirectory
|
|
||||||
adb logcat -G 16M
|
|
||||||
./gradlew JacocoDebugCodeCoverage || (./gradlew androidApp:fetchScreenshots && adb logcat 'InputReader:S' 'chatty:S' 'audio_hw_generic:S' 'LogApiCalls:D' '*:I' -d > ./androidApp/build/reports/androidTests/connected/screenshots/logs.txt)
|
|
||||||
- uses: actions/upload-artifact@v3
|
|
||||||
if: ${{ steps.check-android-changes.outputs.any_modified == 'true' }}
|
|
||||||
with:
|
|
||||||
name: screenshot-espresso
|
|
||||||
path: androidApp/build/reports/androidTests/connected/screenshots
|
|
||||||
retention-days: 2
|
|
||||||
overwrite: true
|
|
||||||
include-hidden-files: true
|
|
||||||
- uses: actions/upload-artifact@v3
|
|
||||||
if: ${{ steps.check-android-changes.outputs.any_modified == 'true' }}
|
|
||||||
with:
|
|
||||||
path: androidApp/build/reports/androidTests/connected/debug/flavors/githubConfig
|
|
||||||
retention-days: 1
|
|
||||||
overwrite: true
|
|
||||||
include-hidden-files: true
|
|
||||||
- uses: actions/upload-artifact@v3
|
|
||||||
if: ${{ steps.check-android-changes.outputs.any_modified == 'true' }}
|
|
||||||
with:
|
|
||||||
name: coverage-espresso
|
|
||||||
path: androidApp/build/reports/jacoco/JacocoDebugCodeCoverage
|
|
||||||
retention-days: 1
|
|
||||||
overwrite: true
|
|
||||||
include-hidden-files: true
|
|
||||||
- name: Clean
|
|
||||||
if: ${{ steps.check-android-changes.outputs.any_modified == 'true' }}
|
|
||||||
run: |
|
|
||||||
docker compose -f .gitea/workflows/assets/docker-compose.yml stop
|
|
||||||
|
67
.gitea/workflows/on_pr_test.yml
Normal file
67
.gitea/workflows/on_pr_test.yml
Normal file
@ -0,0 +1,67 @@
|
|||||||
|
name: PR test
|
||||||
|
on:
|
||||||
|
pull_request:
|
||||||
|
branches:
|
||||||
|
- master
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
integrationTests:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- name: Check out repository code
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
with:
|
||||||
|
fetch-depth: 0
|
||||||
|
- name: Fetch tags
|
||||||
|
run: git fetch --tags -p
|
||||||
|
- uses: KengoTODA/actions-setup-docker-compose@v1
|
||||||
|
with:
|
||||||
|
version: "2.23.3"
|
||||||
|
- name: run selfoss
|
||||||
|
run: |
|
||||||
|
docker compose -f .gitea/workflows/assets/docker-compose.yml up -d
|
||||||
|
- uses: actions/setup-java@v4
|
||||||
|
with:
|
||||||
|
distribution: 'temurin'
|
||||||
|
java-version: '17'
|
||||||
|
- uses: gradle/actions/setup-gradle@v3
|
||||||
|
- uses: android-actions/setup-android@v3
|
||||||
|
- name: Configure gradle...
|
||||||
|
run: mkdir -p ~/.gradle && echo "org.gradle.daemon=false\nignoreGitVersion=true" >> ~/.gradle/gradle.properties
|
||||||
|
- name: Change url until I find a better way to do it
|
||||||
|
run: |
|
||||||
|
sed -i "s/const val DEFAULT_URL = \"http:\/\/10\.0\.2\.2\:8888\"/const val DEFAULT_URL = \"http:\/\/172\.17\.0\.1\:8888\"/g" ./androidApp/src/androidTest/kotlin/bou/amine/apps/readerforselfossv2/android/CommonTests.kt
|
||||||
|
- name: Tests
|
||||||
|
uses: reactivecircus/android-emulator-runner@v2
|
||||||
|
with:
|
||||||
|
api-level: 29
|
||||||
|
profile: pixel_2
|
||||||
|
script: |
|
||||||
|
./gradlew androidApp:clearScreenshotsTask || true
|
||||||
|
./gradlew androidApp:createScreenshotDirectory
|
||||||
|
adb logcat -G 16M
|
||||||
|
./gradlew JacocoDebugCodeCoverage || (./gradlew androidApp:fetchScreenshots && adb logcat 'InputReader:S' 'chatty:S' 'audio_hw_generic:S' 'LogApiCalls:D' '*:I' -d > ./androidApp/build/reports/androidTests/connected/screenshots/logs.txt)
|
||||||
|
- uses: actions/upload-artifact@v3
|
||||||
|
with:
|
||||||
|
name: screenshot-espresso
|
||||||
|
path: androidApp/build/reports/androidTests/connected/screenshots
|
||||||
|
retention-days: 2
|
||||||
|
overwrite: true
|
||||||
|
include-hidden-files: true
|
||||||
|
- uses: actions/upload-artifact@v3
|
||||||
|
with:
|
||||||
|
path: androidApp/build/reports/androidTests/connected/debug/flavors/githubConfig
|
||||||
|
retention-days: 1
|
||||||
|
overwrite: true
|
||||||
|
include-hidden-files: true
|
||||||
|
- uses: actions/upload-artifact@v3
|
||||||
|
with:
|
||||||
|
name: coverage-espresso
|
||||||
|
path: androidApp/build/reports/jacoco/JacocoDebugCodeCoverage
|
||||||
|
retention-days: 1
|
||||||
|
overwrite: true
|
||||||
|
include-hidden-files: true
|
||||||
|
- name: Clean
|
||||||
|
if: always()
|
||||||
|
run: |
|
||||||
|
docker compose -f .gitea/workflows/assets/docker-compose.yml stop
|
@ -1,4 +1,4 @@
|
|||||||
name: Check master code
|
name: Master
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
branches:
|
branches:
|
||||||
@ -6,48 +6,4 @@ on:
|
|||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
build:
|
build:
|
||||||
runs-on: ubuntu-latest
|
uses: ./.gitea/workflows/on_called_build.yml
|
||||||
steps:
|
|
||||||
- name: Check out repository code
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
with:
|
|
||||||
fetch-depth: 0
|
|
||||||
- name: "Check android app changes"
|
|
||||||
id: check-android-changes
|
|
||||||
uses: tj-actions/changed-files@v45
|
|
||||||
with:
|
|
||||||
files: |
|
|
||||||
androidApp/src/**
|
|
||||||
shared/src/commonMain/**
|
|
||||||
shared/src/androidMain/**
|
|
||||||
shared/src/commonTest/**
|
|
||||||
- name: Fetch tags
|
|
||||||
if: ${{ steps.check-android-changes.outputs.any_modified == 'true' }}
|
|
||||||
run: git fetch --tags -p
|
|
||||||
- uses: actions/setup-java@v4
|
|
||||||
if: ${{ steps.check-android-changes.outputs.any_modified == 'true' }}
|
|
||||||
with:
|
|
||||||
distribution: 'temurin'
|
|
||||||
java-version: '17'
|
|
||||||
- uses: gradle/actions/setup-gradle@v3
|
|
||||||
if: ${{ steps.check-android-changes.outputs.any_modified == 'true' }}
|
|
||||||
- uses: android-actions/setup-android@v3
|
|
||||||
if: ${{ steps.check-android-changes.outputs.any_modified == 'true' }}
|
|
||||||
- name: Configure gradle...
|
|
||||||
if: ${{ steps.check-android-changes.outputs.any_modified == 'true' }}
|
|
||||||
run: mkdir -p ~/.gradle && echo "org.gradle.daemon=false\nignoreGitVersion=true" >> ~/.gradle/gradle.properties
|
|
||||||
- name: Build and test
|
|
||||||
if: ${{ steps.check-android-changes.outputs.any_modified == 'true' }}
|
|
||||||
run: ./gradlew build -x testReleaseUnitTest -x testDebugUnitTest -x testGithubConfigReleaseUnitTest -x testGithubConfigDebugUnitTest
|
|
||||||
- name: coverage
|
|
||||||
if: ${{ steps.check-android-changes.outputs.any_modified == 'true' }}
|
|
||||||
run: |
|
|
||||||
./gradlew :koverHtmlReport
|
|
||||||
- uses: actions/upload-artifact@v3
|
|
||||||
if: ${{ steps.check-android-changes.outputs.any_modified == 'true' }}
|
|
||||||
with:
|
|
||||||
name: coverage
|
|
||||||
path: build/reports/kover/html
|
|
||||||
retention-days: 1
|
|
||||||
overwrite: true
|
|
||||||
include-hidden-files: true
|
|
||||||
|
20
CHANGELOG.md
20
CHANGELOG.md
@ -1,3 +1,23 @@
|
|||||||
|
**v125030901
|
||||||
|
|
||||||
|
- Merge pull request 'fix-reload' (#195) from fix-reload into master
|
||||||
|
- fix: Infinite scroll needs loading stats.
|
||||||
|
- fix: do not reload items on resume.
|
||||||
|
- Merge pull request 'tests' (#193) from tests into master
|
||||||
|
- ci: Instrumentation tests coverage in ci.
|
||||||
|
- ci: Instrumentation tests coverage in ci.
|
||||||
|
- ci: Instrumentation tests coverage in ci.
|
||||||
|
- chore: better handling of coroutine dispatchers.
|
||||||
|
- ci: Instrumentation tests coverage in ci.
|
||||||
|
- chore: comment robolectric tests for now.
|
||||||
|
- fix: Fixed source deletion test.
|
||||||
|
- Merge pull request 'Fix alignment changes resetting reader article position' (#190) from davidoskky/ReaderForSelfoss-multiplatform:alignment into master
|
||||||
|
- Refactor star icon handling
|
||||||
|
- Don't restart activity changing alignment
|
||||||
|
- Changelog for v125030711
|
||||||
|
|
||||||
|
--------------------------------------------------------------------
|
||||||
|
|
||||||
**v125030711
|
**v125030711
|
||||||
|
|
||||||
- Merge pull request 'fix: initial status loading issues.' (#192) from connectivity into master
|
- Merge pull request 'fix: initial status loading issues.' (#192) from connectivity into master
|
||||||
|
@ -120,6 +120,7 @@ class HomeActivity :
|
|||||||
binding.swipeRefreshLayout.setOnRefreshListener {
|
binding.swipeRefreshLayout.setOnRefreshListener {
|
||||||
repository.offlineOverride = false
|
repository.offlineOverride = false
|
||||||
lastFetchDone = false
|
lastFetchDone = false
|
||||||
|
items.clear()
|
||||||
getElementsAccordingToTab()
|
getElementsAccordingToTab()
|
||||||
binding.swipeRefreshLayout.isRefreshing = false
|
binding.swipeRefreshLayout.isRefreshing = false
|
||||||
}
|
}
|
||||||
@ -458,23 +459,28 @@ class HomeActivity :
|
|||||||
appendResults: Boolean,
|
appendResults: Boolean,
|
||||||
itemType: ItemType,
|
itemType: ItemType,
|
||||||
) {
|
) {
|
||||||
CountingIdlingResourceSingleton.increment()
|
@Suppress("detekt:ComplexCondition")
|
||||||
binding.swipeRefreshLayout.isRefreshing = true
|
if ((appendResults && items.size > 0) || (!appendResults && items.size == 0)) {
|
||||||
CoroutineScope(Dispatchers.IO).launch {
|
|
||||||
repository.displayedItems = itemType
|
|
||||||
items =
|
|
||||||
if (appendResults) {
|
|
||||||
repository.getOlderItems()
|
|
||||||
} else {
|
|
||||||
repository.getNewerItems()
|
|
||||||
}
|
|
||||||
CountingIdlingResourceSingleton.increment()
|
CountingIdlingResourceSingleton.increment()
|
||||||
launch(Dispatchers.Main) {
|
binding.swipeRefreshLayout.isRefreshing = true
|
||||||
binding.swipeRefreshLayout.isRefreshing = false
|
CoroutineScope(Dispatchers.IO).launch {
|
||||||
handleListResult()
|
repository.displayedItems = itemType
|
||||||
|
items =
|
||||||
|
if (appendResults) {
|
||||||
|
repository.getOlderItems()
|
||||||
|
} else {
|
||||||
|
repository.getNewerItems()
|
||||||
|
}
|
||||||
|
CountingIdlingResourceSingleton.increment()
|
||||||
|
launch(Dispatchers.Main) {
|
||||||
|
binding.swipeRefreshLayout.isRefreshing = false
|
||||||
|
handleListResult()
|
||||||
|
CountingIdlingResourceSingleton.decrement()
|
||||||
|
}
|
||||||
CountingIdlingResourceSingleton.decrement()
|
CountingIdlingResourceSingleton.decrement()
|
||||||
}
|
}
|
||||||
CountingIdlingResourceSingleton.decrement()
|
} else {
|
||||||
|
handleListResult()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -534,7 +540,10 @@ class HomeActivity :
|
|||||||
}
|
}
|
||||||
|
|
||||||
private fun reloadBadges() {
|
private fun reloadBadges() {
|
||||||
if (appSettingsService.isDisplayUnreadCountEnabled() || appSettingsService.isDisplayAllCountEnabled()) {
|
if (appSettingsService.isInfiniteLoadingEnabled() ||
|
||||||
|
appSettingsService.isDisplayUnreadCountEnabled() ||
|
||||||
|
appSettingsService.isDisplayAllCountEnabled()
|
||||||
|
) {
|
||||||
CountingIdlingResourceSingleton.increment()
|
CountingIdlingResourceSingleton.increment()
|
||||||
CoroutineScope(Dispatchers.IO).launch {
|
CoroutineScope(Dispatchers.IO).launch {
|
||||||
repository.reloadBadges()
|
repository.reloadBadges()
|
||||||
|
@ -82,13 +82,14 @@ class MyApp :
|
|||||||
} else {
|
} else {
|
||||||
R.string.network_connectivity_lost
|
R.string.network_connectivity_lost
|
||||||
}
|
}
|
||||||
|
launch(Dispatchers.Main) {
|
||||||
Toast
|
Toast
|
||||||
.makeText(
|
.makeText(
|
||||||
applicationContext,
|
applicationContext,
|
||||||
toastMessage,
|
toastMessage,
|
||||||
Toast.LENGTH_SHORT,
|
Toast.LENGTH_SHORT,
|
||||||
).show()
|
).show()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -30,7 +30,7 @@ import org.kodein.di.instance
|
|||||||
|
|
||||||
class ItemCardAdapter(
|
class ItemCardAdapter(
|
||||||
override val app: Activity,
|
override val app: Activity,
|
||||||
override val items: ArrayList<SelfossModel.Item>,
|
override var items: ArrayList<SelfossModel.Item>,
|
||||||
override val updateHomeItems: (ArrayList<SelfossModel.Item>) -> Unit,
|
override val updateHomeItems: (ArrayList<SelfossModel.Item>) -> Unit,
|
||||||
) : ItemsAdapter<ItemCardAdapter.ViewHolder>() {
|
) : ItemsAdapter<ItemCardAdapter.ViewHolder>() {
|
||||||
override lateinit var binding: CardItemBinding
|
override lateinit var binding: CardItemBinding
|
||||||
|
@ -21,7 +21,7 @@ import org.kodein.di.instance
|
|||||||
|
|
||||||
class ItemListAdapter(
|
class ItemListAdapter(
|
||||||
override val app: Activity,
|
override val app: Activity,
|
||||||
override val items: ArrayList<SelfossModel.Item>,
|
override var items: ArrayList<SelfossModel.Item>,
|
||||||
override val updateHomeItems: (ArrayList<SelfossModel.Item>) -> Unit,
|
override val updateHomeItems: (ArrayList<SelfossModel.Item>) -> Unit,
|
||||||
) : ItemsAdapter<ItemListAdapter.ViewHolder>() {
|
) : ItemsAdapter<ItemListAdapter.ViewHolder>() {
|
||||||
override lateinit var binding: ListItemBinding
|
override lateinit var binding: ListItemBinding
|
||||||
|
@ -21,7 +21,7 @@ import org.kodein.di.DIAware
|
|||||||
abstract class ItemsAdapter<VH : RecyclerView.ViewHolder?> :
|
abstract class ItemsAdapter<VH : RecyclerView.ViewHolder?> :
|
||||||
RecyclerView.Adapter<VH>(),
|
RecyclerView.Adapter<VH>(),
|
||||||
DIAware {
|
DIAware {
|
||||||
abstract val items: ArrayList<SelfossModel.Item>
|
abstract var items: ArrayList<SelfossModel.Item>
|
||||||
abstract val repository: Repository
|
abstract val repository: Repository
|
||||||
abstract val binding: ViewBinding
|
abstract val binding: ViewBinding
|
||||||
abstract val appSettingsService: AppSettingsService
|
abstract val appSettingsService: AppSettingsService
|
||||||
@ -31,8 +31,7 @@ abstract class ItemsAdapter<VH : RecyclerView.ViewHolder?> :
|
|||||||
protected val c: Context get() = app.baseContext
|
protected val c: Context get() = app.baseContext
|
||||||
|
|
||||||
fun updateAllItems(items: ArrayList<SelfossModel.Item>) {
|
fun updateAllItems(items: ArrayList<SelfossModel.Item>) {
|
||||||
this.items.clear()
|
this.items = items
|
||||||
this.items.addAll(items)
|
|
||||||
updateHomeItems(items)
|
updateHomeItems(items)
|
||||||
notifyDataSetChanged()
|
notifyDataSetChanged()
|
||||||
}
|
}
|
||||||
|
17
fastlane/metadata/android/en-US/changelogs/v125030901.txt
Normal file
17
fastlane/metadata/android/en-US/changelogs/v125030901.txt
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
**v125030901**
|
||||||
|
|
||||||
|
- Merge pull request 'fix-reload' (#195) from fix-reload into master
|
||||||
|
- fix: Infinite scroll needs loading stats.
|
||||||
|
- fix: do not reload items on resume.
|
||||||
|
- Merge pull request 'tests' (#193) from tests into master
|
||||||
|
- ci: Instrumentation tests coverage in ci.
|
||||||
|
- ci: Instrumentation tests coverage in ci.
|
||||||
|
- ci: Instrumentation tests coverage in ci.
|
||||||
|
- chore: better handling of coroutine dispatchers.
|
||||||
|
- ci: Instrumentation tests coverage in ci.
|
||||||
|
- chore: comment robolectric tests for now.
|
||||||
|
- fix: Fixed source deletion test.
|
||||||
|
- Merge pull request 'Fix alignment changes resetting reader article position' (#190) from davidoskky/ReaderForSelfoss-multiplatform:alignment into master
|
||||||
|
- Refactor star icon handling
|
||||||
|
- Don't restart activity changing alignment
|
||||||
|
- Changelog for v125030711
|
Reference in New Issue
Block a user