Compare commits
	
		
			1 Commits
		
	
	
		
			v125040991
			...
			edaf6cb79d
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| edaf6cb79d | 
@@ -6,7 +6,8 @@ jobs:
 | 
			
		||||
  BuildAndTestAndCoverage:
 | 
			
		||||
    runs-on: ubuntu-latest
 | 
			
		||||
    steps:
 | 
			
		||||
      - uses: actions/checkout@v4
 | 
			
		||||
      - name: Check out repository code
 | 
			
		||||
        uses: actions/checkout@v4
 | 
			
		||||
        with:
 | 
			
		||||
          fetch-depth: 0
 | 
			
		||||
      - name: "Check android app changes"
 | 
			
		||||
@@ -15,9 +16,6 @@ jobs:
 | 
			
		||||
        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
 | 
			
		||||
@@ -26,6 +24,7 @@ jobs:
 | 
			
		||||
        with:
 | 
			
		||||
          distribution: 'temurin'
 | 
			
		||||
          java-version: '17'
 | 
			
		||||
          cache: gradle
 | 
			
		||||
      - uses: gradle/actions/setup-gradle@v3
 | 
			
		||||
        if: steps.check-android-changes.outputs.any_modified == 'true'
 | 
			
		||||
      - uses: android-actions/setup-android@v3
 | 
			
		||||
@@ -35,7 +34,14 @@ jobs:
 | 
			
		||||
        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
 | 
			
		||||
        run: ./gradlew build -x testReleaseUnitTest -x testDebugUnitTest -x testGithubConfigReleaseUnitTest -x testGithubConfigDebugUnitTest # These tests will be done
 | 
			
		||||
      # TESTS ARE RUN LOCALLY
 | 
			
		||||
      #      - 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
 | 
			
		||||
      - name: coverage
 | 
			
		||||
        if: steps.check-android-changes.outputs.any_modified == 'true'
 | 
			
		||||
        run: |
 | 
			
		||||
@@ -48,3 +54,8 @@ jobs:
 | 
			
		||||
          retention-days: 1
 | 
			
		||||
          overwrite: true
 | 
			
		||||
          include-hidden-files: true
 | 
			
		||||
#      TESTS ARE RUN LOCALLY
 | 
			
		||||
#      - name: Clean
 | 
			
		||||
#        if: always()
 | 
			
		||||
#        run: |
 | 
			
		||||
#          docker compose -f .gitea/workflows/assets/docker-compose.yml stop
 | 
			
		||||
							
								
								
									
										65
									
								
								.gitea/workflows/common_coverage.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										65
									
								
								.gitea/workflows/common_coverage.yml
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,65 @@
 | 
			
		||||
name: Coverage
 | 
			
		||||
on:
 | 
			
		||||
  workflow_call:
 | 
			
		||||
 | 
			
		||||
jobs:
 | 
			
		||||
  BuildAndTestAndCoverage:
 | 
			
		||||
    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: actions/setup-java@v4
 | 
			
		||||
        with:
 | 
			
		||||
          distribution: 'temurin'
 | 
			
		||||
          java-version: '17'
 | 
			
		||||
          cache: gradle
 | 
			
		||||
      - uses: gradle/actions/setup-gradle@v3
 | 
			
		||||
      - uses: android-actions/setup-android@v3
 | 
			
		||||
      - name: Configure gradle...
 | 
			
		||||
        run: mkdir -p ~/.gradle && echo "ignoreGitVersion=true" >> ~/.gradle/gradle.properties
 | 
			
		||||
      - 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
 | 
			
		||||
      - name: Set env url
 | 
			
		||||
        run: |
 | 
			
		||||
          export SELFOSS_URL=172.17.0.1:8888
 | 
			
		||||
      # https://github.com/ReactiveCircus/android-emulator-runner/issues/385
 | 
			
		||||
      - name: Kill crashpad_handler processes
 | 
			
		||||
        if: always()
 | 
			
		||||
        run: |
 | 
			
		||||
          pkill -SIGTERM crashpad_handler || true
 | 
			
		||||
          sleep 5
 | 
			
		||||
          pkill -SIGKILL crashpad_handler || true
 | 
			
		||||
      - name: Tests
 | 
			
		||||
        uses: reactivecircus/android-emulator-runner@v2
 | 
			
		||||
        with:
 | 
			
		||||
          api-level: 29
 | 
			
		||||
          script: |
 | 
			
		||||
            ./gradlew androidApp:connectedAndroidTest
 | 
			
		||||
            killall -INT crashpad_handler || true
 | 
			
		||||
      - uses: actions/upload-artifact@v3
 | 
			
		||||
        if: failure()
 | 
			
		||||
        with:
 | 
			
		||||
          name: failure-espresso
 | 
			
		||||
          path: build/reports/androidTests/connected/screenshots
 | 
			
		||||
          retention-days: 2
 | 
			
		||||
          overwrite: true
 | 
			
		||||
          include-hidden-files: true
 | 
			
		||||
      - uses: actions/upload-artifact@v3
 | 
			
		||||
        with:
 | 
			
		||||
          name: coverage-espresso
 | 
			
		||||
          path: build/reports/coverage/androidTest/githubConfig/debug/connected
 | 
			
		||||
          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: Realease
 | 
			
		||||
name: Create tag
 | 
			
		||||
on:
 | 
			
		||||
  push:
 | 
			
		||||
    branches:
 | 
			
		||||
@@ -7,7 +7,7 @@ on:
 | 
			
		||||
 | 
			
		||||
jobs:
 | 
			
		||||
  build:
 | 
			
		||||
    uses: ./.gitea/workflows/on_called_build.yml
 | 
			
		||||
    uses: ./.gitea/workflows/common_build.yml
 | 
			
		||||
  createTagAndChangelog:
 | 
			
		||||
    runs-on: ubuntu-latest
 | 
			
		||||
    needs: build
 | 
			
		||||
@@ -86,6 +86,7 @@ jobs:
 | 
			
		||||
        with:
 | 
			
		||||
          distribution: 'temurin'
 | 
			
		||||
          java-version: '17'
 | 
			
		||||
          cache: gradle
 | 
			
		||||
      - name: Setup Android SDK
 | 
			
		||||
        uses: android-actions/setup-android@v3
 | 
			
		||||
      - name: Configure gradle...
 | 
			
		||||
 
 | 
			
		||||
@@ -1,89 +1,156 @@
 | 
			
		||||
name: PR
 | 
			
		||||
name: Check PR code
 | 
			
		||||
on:
 | 
			
		||||
  pull_request:
 | 
			
		||||
    branches:
 | 
			
		||||
      - master
 | 
			
		||||
 | 
			
		||||
jobs:
 | 
			
		||||
  PR:
 | 
			
		||||
    runs-on: ubuntu-latest
 | 
			
		||||
    steps:
 | 
			
		||||
      - name: Check out repository code
 | 
			
		||||
        uses: actions/checkout@v4
 | 
			
		||||
      - uses: actions/setup-java@v4
 | 
			
		||||
        with:
 | 
			
		||||
          distribution: 'temurin'
 | 
			
		||||
          java-version: '17'
 | 
			
		||||
      - name: Install klint
 | 
			
		||||
        run: curl -sSLO https://github.com/pinterest/ktlint/releases/download/1.5.0/ktlint && chmod a+x ktlint && mv ktlint /usr/local/bin/
 | 
			
		||||
      - name: Install detekt
 | 
			
		||||
        run: curl -sSLO https://github.com/detekt/detekt/releases/download/v1.23.7/detekt-cli-1.23.7.zip && unzip detekt-cli-1.23.7.zip
 | 
			
		||||
      - name: Linting...
 | 
			
		||||
        run: ktlint 'shared/**/*.kt' 'androidApp/**/*.kt' '!shared/build'
 | 
			
		||||
      - name: Detecting...
 | 
			
		||||
        run: ./detekt-cli-1.23.7/bin/detekt-cli -c detekt.yml --excludes '**/shared/build/**/*.kt'
 | 
			
		||||
  translations:
 | 
			
		||||
  BuildAndTestAndCoverage:
 | 
			
		||||
    runs-on: ubuntu-latest
 | 
			
		||||
    steps:
 | 
			
		||||
      - name: Check out repository code
 | 
			
		||||
        uses: actions/checkout@v4
 | 
			
		||||
        with:
 | 
			
		||||
          fetch-depth: 0
 | 
			
		||||
      - name: "Check translations changes"
 | 
			
		||||
        id: check-translations-changes
 | 
			
		||||
        uses: tj-actions/changed-files@v45
 | 
			
		||||
      - name: Fetch tags
 | 
			
		||||
        run: git fetch --tags -p
 | 
			
		||||
      - uses: actions/setup-java@v4
 | 
			
		||||
        with:
 | 
			
		||||
          files: |
 | 
			
		||||
            androidApp/src/main/res/values/strings.xml
 | 
			
		||||
      - name: upload translation sources
 | 
			
		||||
        if: steps.check-translations-changes.outputs.any_modified == 'true'
 | 
			
		||||
        uses: crowdin/github-action@v2
 | 
			
		||||
          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 "ignoreGitVersion=true" >> ~/.gradle/gradle.properties
 | 
			
		||||
      - uses: KengoTODA/actions-setup-docker-compose@v1
 | 
			
		||||
        with:
 | 
			
		||||
          config: './.gitea/workflows/assets/crowdin.yml'
 | 
			
		||||
          upload_sources: true
 | 
			
		||||
          upload_translations: false
 | 
			
		||||
          download_translations: false
 | 
			
		||||
          create_pull_request: false
 | 
			
		||||
          push_translations: false
 | 
			
		||||
        env:
 | 
			
		||||
          CROWDIN_PROJECT_ID: ${{ secrets.CROWDIN_PROJECT_ID }}
 | 
			
		||||
          CROWDIN_PERSONAL_TOKEN: ${{ secrets.CROWDIN_PERSONAL_TOKEN }}
 | 
			
		||||
      - name: wait
 | 
			
		||||
        if: steps.check-translations-changes.outputs.any_modified == 'true'
 | 
			
		||||
        run: sleep 10s
 | 
			
		||||
      - name: download translations
 | 
			
		||||
        if: steps.check-translations-changes.outputs.any_modified == 'true'
 | 
			
		||||
        uses: crowdin/github-action@v2
 | 
			
		||||
        with:
 | 
			
		||||
          config: './.gitea/workflows/assets/crowdin.yml'
 | 
			
		||||
          upload_sources: false
 | 
			
		||||
          upload_translations: false
 | 
			
		||||
          download_translations: true
 | 
			
		||||
          create_pull_request: false
 | 
			
		||||
          push_translations: false
 | 
			
		||||
        env:
 | 
			
		||||
          CROWDIN_PROJECT_ID: ${{ secrets.CROWDIN_PROJECT_ID }}
 | 
			
		||||
          CROWDIN_PERSONAL_TOKEN: ${{ secrets.CROWDIN_PERSONAL_TOKEN }}
 | 
			
		||||
      - name: Check for uncommitted changes
 | 
			
		||||
        if: steps.check-translations-changes.outputs.any_modified == 'true'
 | 
			
		||||
        id: check-changes
 | 
			
		||||
        uses: mskri/check-uncommitted-changes-action@v1.0.1
 | 
			
		||||
      - name: Commit Changes
 | 
			
		||||
        if: steps.check-translations-changes.outputs.any_modified == 'true' && steps.check-changes.outputs.changes != ''
 | 
			
		||||
          version: "2.23.3"
 | 
			
		||||
      - name: run selfoss
 | 
			
		||||
        run: |
 | 
			
		||||
          git config --global user.email aminecmi+giteadrone@pm.me
 | 
			
		||||
          git config --global user.name giteadrone
 | 
			
		||||
          git add ./androidApp/src/main/res/*
 | 
			
		||||
          git commit -m "translation: translation files"
 | 
			
		||||
      - name: Push changes
 | 
			
		||||
        if: steps.check-translations-changes.outputs.any_modified == 'true' && steps.check-changes.outputs.changes != ''
 | 
			
		||||
        uses: appleboy/git-push-action@v1.0.0
 | 
			
		||||
          docker compose -f .gitea/workflows/assets/docker-compose.yml up -d
 | 
			
		||||
      - name: Change url until I find a better way to do it
 | 
			
		||||
        run: |
 | 
			
		||||
          sed -i "s/val defaultUrl = \"http:\/\/10\.0\.2\.2\:8888\"/val defaultUrl = \"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:
 | 
			
		||||
          author_name: giteadrone
 | 
			
		||||
          author_email: aminecmi+giteadrone@pm.me
 | 
			
		||||
          remote: ${{ secrets.REMOTE_URL }}
 | 
			
		||||
          ssh_key: ${{ secrets.PRIVATE_KEY }}
 | 
			
		||||
          branch: ${{ github.head_ref || github.ref_name }}
 | 
			
		||||
  build:
 | 
			
		||||
    needs: Lint
 | 
			
		||||
    uses: ./.gitea/workflows/on_called_build.yml
 | 
			
		||||
          api-level: 29
 | 
			
		||||
          profile: pixel_2
 | 
			
		||||
          script: |
 | 
			
		||||
            ./gradlew androidApp:clearScreenshotsTask || true
 | 
			
		||||
            ./gradlew androidApp:createScreenshotDirectory
 | 
			
		||||
            adb logcat -G 16M
 | 
			
		||||
            ./gradlew JacocoDebugCodeCoverage || true
 | 
			
		||||
            ./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: always()
 | 
			
		||||
        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: always()
 | 
			
		||||
        with:
 | 
			
		||||
          name: result-espresso
 | 
			
		||||
          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
 | 
			
		||||
 | 
			
		||||
#  Lint:
 | 
			
		||||
#    runs-on: ubuntu-latest
 | 
			
		||||
#    steps:
 | 
			
		||||
#      - name: Check out repository code
 | 
			
		||||
#        uses: actions/checkout@v4
 | 
			
		||||
#      - uses: actions/setup-java@v4
 | 
			
		||||
#        with:
 | 
			
		||||
#          distribution: 'temurin'
 | 
			
		||||
#          java-version: '17'
 | 
			
		||||
#          cache: gradle
 | 
			
		||||
#      - name: Install klint
 | 
			
		||||
#        run: curl -sSLO https://github.com/pinterest/ktlint/releases/download/1.5.0/ktlint && chmod a+x ktlint && mv ktlint /usr/local/bin/
 | 
			
		||||
#      - name: Install detekt
 | 
			
		||||
#        run: curl -sSLO https://github.com/detekt/detekt/releases/download/v1.23.7/detekt-cli-1.23.7.zip && unzip detekt-cli-1.23.7.zip
 | 
			
		||||
#      - name: Linting...
 | 
			
		||||
#        run: ktlint 'shared/**/*.kt' 'androidApp/**/*.kt' '!shared/build'
 | 
			
		||||
#      - name: Detecting...
 | 
			
		||||
#        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"
 | 
			
		||||
#        id: check-translations-changes
 | 
			
		||||
#        uses: tj-actions/changed-files@v45
 | 
			
		||||
#        with:
 | 
			
		||||
#          files: |
 | 
			
		||||
#            androidApp/src/main/res/values/strings.xml
 | 
			
		||||
#      - name: upload translation sources
 | 
			
		||||
#        if: steps.check-api-changes.outputs.any_modified == 'true'
 | 
			
		||||
#        uses: crowdin/github-action@v2
 | 
			
		||||
#        with:
 | 
			
		||||
#          config: './.gitea/workflows/assets/crowdin.yml'
 | 
			
		||||
#          upload_sources: true
 | 
			
		||||
#          upload_translations: false
 | 
			
		||||
#          download_translations: false
 | 
			
		||||
#          create_pull_request: false
 | 
			
		||||
#          push_translations: false
 | 
			
		||||
#        env:
 | 
			
		||||
#          CROWDIN_PROJECT_ID: ${{ secrets.CROWDIN_PROJECT_ID }}
 | 
			
		||||
#          CROWDIN_PERSONAL_TOKEN: ${{ secrets.CROWDIN_PERSONAL_TOKEN }}
 | 
			
		||||
#      - name: wait
 | 
			
		||||
#        if: steps.check-api-changes.outputs.any_modified == 'true'
 | 
			
		||||
#        run: sleep 10s
 | 
			
		||||
#      - name: download translations
 | 
			
		||||
#        if: steps.check-api-changes.outputs.any_modified == 'true'
 | 
			
		||||
#        uses: crowdin/github-action@v2
 | 
			
		||||
#        with:
 | 
			
		||||
#          config: './.gitea/workflows/assets/crowdin.yml'
 | 
			
		||||
#          upload_sources: false
 | 
			
		||||
#          upload_translations: false
 | 
			
		||||
#          download_translations: true
 | 
			
		||||
#          create_pull_request: false
 | 
			
		||||
#          push_translations: false
 | 
			
		||||
#        env:
 | 
			
		||||
#          CROWDIN_PROJECT_ID: ${{ secrets.CROWDIN_PROJECT_ID }}
 | 
			
		||||
#          CROWDIN_PERSONAL_TOKEN: ${{ secrets.CROWDIN_PERSONAL_TOKEN }}
 | 
			
		||||
#      - name: Check for uncommitted changes
 | 
			
		||||
#        if: steps.check-api-changes.outputs.any_modified == 'true'
 | 
			
		||||
#        id: check-changes
 | 
			
		||||
#        uses: mskri/check-uncommitted-changes-action@v1.0.1
 | 
			
		||||
#      - name: Commit Changes
 | 
			
		||||
#        if: steps.check-api-changes.outputs.any_modified == 'true' && steps.check-changes.outputs.changes != ''
 | 
			
		||||
#        run: |
 | 
			
		||||
#          git config --global user.email aminecmi+giteadrone@pm.me
 | 
			
		||||
#          git config --global user.name giteadrone
 | 
			
		||||
#          git add ./androidApp/src/main/res/*
 | 
			
		||||
#          git commit -m "translation: translation files"
 | 
			
		||||
#      - name: Push changes
 | 
			
		||||
#        if: steps.check-api-changes.outputs.any_modified == 'true' && steps.check-changes.outputs.changes != ''
 | 
			
		||||
#        uses: appleboy/git-push-action@v1.0.0
 | 
			
		||||
#        with:
 | 
			
		||||
#          author_name: giteadrone
 | 
			
		||||
#          author_email: aminecmi+giteadrone@pm.me
 | 
			
		||||
#          remote: ${{ secrets.REMOTE_URL }}
 | 
			
		||||
#          ssh_key: ${{ secrets.PRIVATE_KEY }}
 | 
			
		||||
#          branch: ${{ github.head_ref || github.ref_name }}
 | 
			
		||||
#  build:
 | 
			
		||||
#    needs: Lint
 | 
			
		||||
#    uses: ./.gitea/workflows/common_build.yml
 | 
			
		||||
 
 | 
			
		||||
@@ -1,67 +0,0 @@
 | 
			
		||||
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: Master
 | 
			
		||||
name: Check master code
 | 
			
		||||
on:
 | 
			
		||||
  push:
 | 
			
		||||
    branches:
 | 
			
		||||
@@ -6,4 +6,4 @@ on:
 | 
			
		||||
 | 
			
		||||
jobs:
 | 
			
		||||
  build:
 | 
			
		||||
    uses: ./.gitea/workflows/on_called_build.yml
 | 
			
		||||
    uses: ./.gitea/workflows/common_build.yml
 | 
			
		||||
							
								
								
									
										20
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										20
									
								
								CHANGELOG.md
									
									
									
									
									
								
							@@ -1,23 +1,3 @@
 | 
			
		||||
**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
 | 
			
		||||
 | 
			
		||||
- Merge pull request 'fix: initial status loading issues.' (#192) from connectivity into master
 | 
			
		||||
 
 | 
			
		||||
@@ -6,7 +6,6 @@ import androidx.test.espresso.IdlingRegistry
 | 
			
		||||
import androidx.test.espresso.action.ViewActions.click
 | 
			
		||||
import androidx.test.espresso.assertion.ViewAssertions.matches
 | 
			
		||||
import androidx.test.espresso.matcher.ViewMatchers.isDisplayed
 | 
			
		||||
import androidx.test.espresso.matcher.ViewMatchers.isRoot
 | 
			
		||||
import androidx.test.espresso.matcher.ViewMatchers.isSelected
 | 
			
		||||
import androidx.test.espresso.matcher.ViewMatchers.withText
 | 
			
		||||
import androidx.test.ext.junit.rules.ActivityScenarioRule
 | 
			
		||||
@@ -97,7 +96,6 @@ class `3-SettingsActivityTest` : WithANRException() {
 | 
			
		||||
    @Test
 | 
			
		||||
    fun testAbout() {
 | 
			
		||||
        onView(withText(R.string.action_about)).perform(click())
 | 
			
		||||
        onView(isRoot()).perform(waitUntilShown("ACRA", 30000))
 | 
			
		||||
        onView(withText("ACRA")).check(matches(isDisplayed()))
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -35,13 +35,13 @@ import java.io.IOException
 | 
			
		||||
import java.util.Locale
 | 
			
		||||
 | 
			
		||||
// For now, do not move this as it is modified by the integration tests
 | 
			
		||||
const val DEFAULT_URL = "http://10.0.2.2:8888"
 | 
			
		||||
val defaultUrl = "http://10.0.2.2:8888"
 | 
			
		||||
 | 
			
		||||
fun performLogin(someUrl: String? = null) {
 | 
			
		||||
    Log.i("AUTOMATION", "The url used will be ${if (!someUrl.isNullOrEmpty()) someUrl else DEFAULT_URL}")
 | 
			
		||||
    Log.i("AUTOMATION", "The url used will be ${if (!someUrl.isNullOrEmpty()) someUrl else defaultUrl}")
 | 
			
		||||
    onView(withId(R.id.urlView)).perform(click()).perform(
 | 
			
		||||
        typeTextIntoFocusedView(
 | 
			
		||||
            if (!someUrl.isNullOrEmpty()) someUrl else DEFAULT_URL,
 | 
			
		||||
            if (!someUrl.isNullOrEmpty()) someUrl else defaultUrl,
 | 
			
		||||
        ),
 | 
			
		||||
    )
 | 
			
		||||
    onView(withId(R.id.signInButton)).perform(click())
 | 
			
		||||
@@ -142,7 +142,7 @@ fun testAddSourceWithUrl(
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
fun checkHomeLoadingDone() {
 | 
			
		||||
    onView(withId(R.id.swipeRefreshLayout)).inRoot(not(isDialog())).perform(waitForRecyclerViewToStopLoading(300000))
 | 
			
		||||
    onView(withId(R.id.swipeRefreshLayout)).inRoot(not(isDialog())).perform(waitUntilNotLoading(300000))
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
@Suppress("detekt:UtilityClassWithPublicConstructor")
 | 
			
		||||
@@ -160,7 +160,7 @@ open class WithANRException {
 | 
			
		||||
                    "default root matcher, it may be picking a root that never takes focus. " +
 | 
			
		||||
                    "Root:",
 | 
			
		||||
            )
 | 
			
		||||
        private const val OTHER_EXCEPTION = "System Ul isn't responding"
 | 
			
		||||
        private val otherException = "System Ul isn't responding"
 | 
			
		||||
 | 
			
		||||
        private fun handleAnrDialogue() {
 | 
			
		||||
            val device = UiDevice.getInstance(getInstrumentation())
 | 
			
		||||
@@ -175,7 +175,7 @@ open class WithANRException {
 | 
			
		||||
            Espresso.setFailureHandler { error, viewMatcher ->
 | 
			
		||||
 | 
			
		||||
                takeScreenshot()
 | 
			
		||||
                if (error.message!!.contains(OTHER_EXCEPTION)) {
 | 
			
		||||
                if (error.message!!.contains(otherException)) {
 | 
			
		||||
                    handleAnrDialogue()
 | 
			
		||||
                } else if (error.message!!.contains(rootViewWithoutFocusExceptionMsg) &&
 | 
			
		||||
                    anrCount < 20
 | 
			
		||||
@@ -192,7 +192,6 @@ open class WithANRException {
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
@Suppress("detekt:NestedBlockDepth")
 | 
			
		||||
fun takeScreenshot() {
 | 
			
		||||
    try {
 | 
			
		||||
        val bitmap = getInstrumentation().uiAutomation.takeScreenshot()
 | 
			
		||||
 
 | 
			
		||||
@@ -18,7 +18,6 @@ import androidx.test.espresso.UiController
 | 
			
		||||
import androidx.test.espresso.ViewAction
 | 
			
		||||
import androidx.test.espresso.matcher.RootMatchers.isPlatformPopup
 | 
			
		||||
import androidx.test.espresso.matcher.ViewMatchers.hasSibling
 | 
			
		||||
import androidx.test.espresso.matcher.ViewMatchers.isRoot
 | 
			
		||||
import androidx.test.espresso.matcher.ViewMatchers.withChild
 | 
			
		||||
import androidx.test.espresso.matcher.ViewMatchers.withClassName
 | 
			
		||||
import androidx.test.espresso.matcher.ViewMatchers.withId
 | 
			
		||||
@@ -54,50 +53,11 @@ fun withError(
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
fun waitUntilShown(
 | 
			
		||||
    viewText: String,
 | 
			
		||||
    millis: Long,
 | 
			
		||||
): ViewAction {
 | 
			
		||||
    return object : ViewAction {
 | 
			
		||||
        override fun getConstraints(): Matcher<View> = isRoot()
 | 
			
		||||
 | 
			
		||||
        override fun getDescription(): String = "wait for $millis millis, for a specific view with text <$viewText> to be visible."
 | 
			
		||||
 | 
			
		||||
        override fun perform(
 | 
			
		||||
            uiController: UiController,
 | 
			
		||||
            view: View,
 | 
			
		||||
        ) {
 | 
			
		||||
            uiController.loopMainThreadUntilIdle()
 | 
			
		||||
            val startTime = System.currentTimeMillis()
 | 
			
		||||
            val endTime = startTime + millis
 | 
			
		||||
            val viewMatcher = withText(viewText)
 | 
			
		||||
 | 
			
		||||
            do {
 | 
			
		||||
                for (child in TreeIterables.breadthFirstViewTraversal(view)) {
 | 
			
		||||
                    if (viewMatcher.matches(child) && child.isShown) {
 | 
			
		||||
                        return
 | 
			
		||||
                    }
 | 
			
		||||
                }
 | 
			
		||||
 | 
			
		||||
                uiController.loopMainThreadForAtLeast(100)
 | 
			
		||||
            } while (System.currentTimeMillis() < endTime)
 | 
			
		||||
 | 
			
		||||
            // timeout happens
 | 
			
		||||
            throw PerformException
 | 
			
		||||
                .Builder()
 | 
			
		||||
                .withActionDescription(this.description)
 | 
			
		||||
                .withViewDescription(HumanReadables.describe(view))
 | 
			
		||||
                .withCause(TimeoutException())
 | 
			
		||||
                .build()
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
fun waitForRecyclerViewToStopLoading(millis: Long): ViewAction {
 | 
			
		||||
fun waitUntilNotLoading(millis: Long): ViewAction {
 | 
			
		||||
    return object : ViewAction {
 | 
			
		||||
        override fun getConstraints(): Matcher<View> = any(View::class.java)
 | 
			
		||||
 | 
			
		||||
        override fun getDescription(): String = "wait for  $millis millis for the recyclerview to stop loading."
 | 
			
		||||
        override fun getDescription(): String = "wait for a specific view is not loading during $millis millis."
 | 
			
		||||
 | 
			
		||||
        override fun perform(
 | 
			
		||||
            uiController: UiController,
 | 
			
		||||
 
 | 
			
		||||
@@ -120,7 +120,6 @@ class HomeActivity :
 | 
			
		||||
        binding.swipeRefreshLayout.setOnRefreshListener {
 | 
			
		||||
            repository.offlineOverride = false
 | 
			
		||||
            lastFetchDone = false
 | 
			
		||||
            items.clear()
 | 
			
		||||
            getElementsAccordingToTab()
 | 
			
		||||
            binding.swipeRefreshLayout.isRefreshing = false
 | 
			
		||||
        }
 | 
			
		||||
@@ -459,28 +458,23 @@ class HomeActivity :
 | 
			
		||||
        appendResults: Boolean,
 | 
			
		||||
        itemType: ItemType,
 | 
			
		||||
    ) {
 | 
			
		||||
        @Suppress("detekt:ComplexCondition")
 | 
			
		||||
        if ((appendResults && items.size > 0) || (!appendResults && items.size == 0)) {
 | 
			
		||||
            CountingIdlingResourceSingleton.increment()
 | 
			
		||||
            binding.swipeRefreshLayout.isRefreshing = true
 | 
			
		||||
            CoroutineScope(Dispatchers.IO).launch {
 | 
			
		||||
                repository.displayedItems = itemType
 | 
			
		||||
                items =
 | 
			
		||||
                    if (appendResults) {
 | 
			
		||||
                        repository.getOlderItems()
 | 
			
		||||
                    } else {
 | 
			
		||||
                        repository.getNewerItems()
 | 
			
		||||
                    }
 | 
			
		||||
                CountingIdlingResourceSingleton.increment()
 | 
			
		||||
                launch(Dispatchers.Main) {
 | 
			
		||||
                    binding.swipeRefreshLayout.isRefreshing = false
 | 
			
		||||
                    handleListResult()
 | 
			
		||||
                    CountingIdlingResourceSingleton.decrement()
 | 
			
		||||
        CountingIdlingResourceSingleton.increment()
 | 
			
		||||
        binding.swipeRefreshLayout.isRefreshing = true
 | 
			
		||||
        CoroutineScope(Dispatchers.IO).launch {
 | 
			
		||||
            repository.displayedItems = itemType
 | 
			
		||||
            items =
 | 
			
		||||
                if (appendResults) {
 | 
			
		||||
                    repository.getOlderItems()
 | 
			
		||||
                } else {
 | 
			
		||||
                    repository.getNewerItems()
 | 
			
		||||
                }
 | 
			
		||||
            CountingIdlingResourceSingleton.increment()
 | 
			
		||||
            launch(Dispatchers.Main) {
 | 
			
		||||
                binding.swipeRefreshLayout.isRefreshing = false
 | 
			
		||||
                handleListResult()
 | 
			
		||||
                CountingIdlingResourceSingleton.decrement()
 | 
			
		||||
            }
 | 
			
		||||
        } else {
 | 
			
		||||
            handleListResult()
 | 
			
		||||
            CountingIdlingResourceSingleton.decrement()
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
@@ -540,10 +534,7 @@ class HomeActivity :
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    private fun reloadBadges() {
 | 
			
		||||
        if (appSettingsService.isInfiniteLoadingEnabled() ||
 | 
			
		||||
            appSettingsService.isDisplayUnreadCountEnabled() ||
 | 
			
		||||
            appSettingsService.isDisplayAllCountEnabled()
 | 
			
		||||
        ) {
 | 
			
		||||
        if (appSettingsService.isDisplayUnreadCountEnabled() || appSettingsService.isDisplayAllCountEnabled()) {
 | 
			
		||||
            CountingIdlingResourceSingleton.increment()
 | 
			
		||||
            CoroutineScope(Dispatchers.IO).launch {
 | 
			
		||||
                repository.reloadBadges()
 | 
			
		||||
 
 | 
			
		||||
@@ -132,7 +132,6 @@ class LoginActivity :
 | 
			
		||||
        showProgress(false)
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    @Suppress("detekt:LongMethod")
 | 
			
		||||
    private fun attemptLogin() {
 | 
			
		||||
        // Reset errors.
 | 
			
		||||
        binding.urlView.error = null
 | 
			
		||||
@@ -311,7 +310,6 @@ class LoginActivity :
 | 
			
		||||
                    .withAboutSpecial2Description(AppSettingsService.BUG_URL)
 | 
			
		||||
                    .withAboutSpecial1("Project Page")
 | 
			
		||||
                    .withAboutSpecial1Description(AppSettingsService.SOURCE_URL)
 | 
			
		||||
                    .withShowLoadingProgress(false)
 | 
			
		||||
                    .start(this)
 | 
			
		||||
                true
 | 
			
		||||
            }
 | 
			
		||||
 
 | 
			
		||||
@@ -82,14 +82,13 @@ class MyApp :
 | 
			
		||||
                        } else {
 | 
			
		||||
                            R.string.network_connectivity_lost
 | 
			
		||||
                        }
 | 
			
		||||
                    launch(Dispatchers.Main) {
 | 
			
		||||
                        Toast
 | 
			
		||||
                            .makeText(
 | 
			
		||||
                                applicationContext,
 | 
			
		||||
                                toastMessage,
 | 
			
		||||
                                Toast.LENGTH_SHORT,
 | 
			
		||||
                            ).show()
 | 
			
		||||
                    }
 | 
			
		||||
 | 
			
		||||
                    Toast
 | 
			
		||||
                        .makeText(
 | 
			
		||||
                            applicationContext,
 | 
			
		||||
                            toastMessage,
 | 
			
		||||
                            Toast.LENGTH_SHORT,
 | 
			
		||||
                        ).show()
 | 
			
		||||
                }
 | 
			
		||||
            }
 | 
			
		||||
        }
 | 
			
		||||
 
 | 
			
		||||
@@ -30,7 +30,7 @@ import org.kodein.di.instance
 | 
			
		||||
 | 
			
		||||
class ItemCardAdapter(
 | 
			
		||||
    override val app: Activity,
 | 
			
		||||
    override var items: ArrayList<SelfossModel.Item>,
 | 
			
		||||
    override val items: ArrayList<SelfossModel.Item>,
 | 
			
		||||
    override val updateHomeItems: (ArrayList<SelfossModel.Item>) -> Unit,
 | 
			
		||||
) : ItemsAdapter<ItemCardAdapter.ViewHolder>() {
 | 
			
		||||
    override lateinit var binding: CardItemBinding
 | 
			
		||||
 
 | 
			
		||||
@@ -21,7 +21,7 @@ import org.kodein.di.instance
 | 
			
		||||
 | 
			
		||||
class ItemListAdapter(
 | 
			
		||||
    override val app: Activity,
 | 
			
		||||
    override var items: ArrayList<SelfossModel.Item>,
 | 
			
		||||
    override val items: ArrayList<SelfossModel.Item>,
 | 
			
		||||
    override val updateHomeItems: (ArrayList<SelfossModel.Item>) -> Unit,
 | 
			
		||||
) : ItemsAdapter<ItemListAdapter.ViewHolder>() {
 | 
			
		||||
    override lateinit var binding: ListItemBinding
 | 
			
		||||
 
 | 
			
		||||
@@ -21,7 +21,7 @@ import org.kodein.di.DIAware
 | 
			
		||||
abstract class ItemsAdapter<VH : RecyclerView.ViewHolder?> :
 | 
			
		||||
    RecyclerView.Adapter<VH>(),
 | 
			
		||||
    DIAware {
 | 
			
		||||
    abstract var items: ArrayList<SelfossModel.Item>
 | 
			
		||||
    abstract val items: ArrayList<SelfossModel.Item>
 | 
			
		||||
    abstract val repository: Repository
 | 
			
		||||
    abstract val binding: ViewBinding
 | 
			
		||||
    abstract val appSettingsService: AppSettingsService
 | 
			
		||||
@@ -31,7 +31,8 @@ abstract class ItemsAdapter<VH : RecyclerView.ViewHolder?> :
 | 
			
		||||
    protected val c: Context get() = app.baseContext
 | 
			
		||||
 | 
			
		||||
    fun updateAllItems(items: ArrayList<SelfossModel.Item>) {
 | 
			
		||||
        this.items = items
 | 
			
		||||
        this.items.clear()
 | 
			
		||||
        this.items.addAll(items)
 | 
			
		||||
        updateHomeItems(items)
 | 
			
		||||
        notifyDataSetChanged()
 | 
			
		||||
    }
 | 
			
		||||
 
 | 
			
		||||
@@ -12,7 +12,6 @@ import androidx.recyclerview.widget.RecyclerView
 | 
			
		||||
import bou.amine.apps.readerforselfossv2.android.R
 | 
			
		||||
import bou.amine.apps.readerforselfossv2.android.UpsertSourceActivity
 | 
			
		||||
import bou.amine.apps.readerforselfossv2.android.databinding.SourceListItemBinding
 | 
			
		||||
import bou.amine.apps.readerforselfossv2.android.testing.CountingIdlingResourceSingleton
 | 
			
		||||
import bou.amine.apps.readerforselfossv2.android.utils.glide.circularDrawable
 | 
			
		||||
import bou.amine.apps.readerforselfossv2.model.SelfossModel
 | 
			
		||||
import bou.amine.apps.readerforselfossv2.repository.Repository
 | 
			
		||||
@@ -105,10 +104,8 @@ class SourcesListAdapter(
 | 
			
		||||
            source: SelfossModel.SourceDetail,
 | 
			
		||||
            position: Int,
 | 
			
		||||
        ) {
 | 
			
		||||
            CountingIdlingResourceSingleton.increment()
 | 
			
		||||
            CoroutineScope(Dispatchers.IO).launch {
 | 
			
		||||
                val successfullyDeletedSource = repository.deleteSource(source.id, source.title)
 | 
			
		||||
                CountingIdlingResourceSingleton.increment()
 | 
			
		||||
                launch(Dispatchers.Main) {
 | 
			
		||||
                    if (successfullyDeletedSource) {
 | 
			
		||||
                        items.removeAt(position)
 | 
			
		||||
@@ -122,9 +119,7 @@ class SourcesListAdapter(
 | 
			
		||||
                                Toast.LENGTH_SHORT,
 | 
			
		||||
                            ).show()
 | 
			
		||||
                    }
 | 
			
		||||
                    CountingIdlingResourceSingleton.decrement()
 | 
			
		||||
                }
 | 
			
		||||
                CountingIdlingResourceSingleton.decrement()
 | 
			
		||||
            }
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 
 | 
			
		||||
@@ -124,7 +124,6 @@ class SettingsActivity :
 | 
			
		||||
                        LibsBuilder()
 | 
			
		||||
                            .withAboutIconShown(true)
 | 
			
		||||
                            .withAboutVersionShown(true)
 | 
			
		||||
                            .withShowLoadingProgress(false)
 | 
			
		||||
                            .start(it)
 | 
			
		||||
                    }
 | 
			
		||||
                    true
 | 
			
		||||
 
 | 
			
		||||
@@ -1,17 +0,0 @@
 | 
			
		||||
**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
 | 
			
		||||
@@ -32,7 +32,6 @@ import io.ktor.utils.io.charsets.Charsets
 | 
			
		||||
import io.ktor.utils.io.core.toByteArray
 | 
			
		||||
import kotlinx.coroutines.CoroutineScope
 | 
			
		||||
import kotlinx.coroutines.Dispatchers
 | 
			
		||||
import kotlinx.coroutines.IO
 | 
			
		||||
import kotlinx.coroutines.launch
 | 
			
		||||
import kotlinx.serialization.json.Json
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user