Compare commits
2 Commits
develop
...
michaelk/d
Author | SHA1 | Date | |
---|---|---|---|
|
65f70252a8 | ||
|
5258e3a1cc |
1
.gitattributes
vendored
1
.gitattributes
vendored
@ -1,2 +1 @@
|
|||||||
**/snapshots/**/*.png filter=lfs diff=lfs merge=lfs -text
|
**/snapshots/**/*.png filter=lfs diff=lfs merge=lfs -text
|
||||||
**/src/androidTest/assets/*.realm filter=lfs diff=lfs merge=lfs -text
|
|
||||||
|
59
.github/ISSUE_TEMPLATE/release.yml
vendored
59
.github/ISSUE_TEMPLATE/release.yml
vendored
@ -10,6 +10,7 @@ body:
|
|||||||
id: checklist
|
id: checklist
|
||||||
attributes:
|
attributes:
|
||||||
label: Release checklist
|
label: Release checklist
|
||||||
|
description: For the template example, we are releasing the version 1.2.3. Replace 1.2.3 with the version in the issue body.
|
||||||
placeholder: |
|
placeholder: |
|
||||||
If you are reading this, you have deleted the content of the release template: undo the deletion or start again.
|
If you are reading this, you have deleted the content of the release template: undo the deletion or start again.
|
||||||
value: |
|
value: |
|
||||||
@ -19,11 +20,34 @@ body:
|
|||||||
- [ ] Check the update of the store descriptions (using Google Translate if necessary) to ensure that the changes are acceptable to be published to the stores.
|
- [ ] Check the update of the store descriptions (using Google Translate if necessary) to ensure that the changes are acceptable to be published to the stores.
|
||||||
- [ ] While Weblate is locked, and after the PR from Weblate has been merged, handle all the TODOs in the main `strings.xml` file
|
- [ ] While Weblate is locked, and after the PR from Weblate has been merged, handle all the TODOs in the main `strings.xml` file
|
||||||
- [ ] Run the script `./tools/release/pushPlayStoreMetaData.sh`. You can check in the GooglePlay console the Activity log to check the effect.
|
- [ ] Run the script `./tools/release/pushPlayStoreMetaData.sh`. You can check in the GooglePlay console the Activity log to check the effect.
|
||||||
|
|
||||||
- [ ] Ensure all [the required PRs](https://github.com/vector-im/element-android/pulls?q=is%3Aopen+is%3Apr+label%3AZ-NextRelease) have been merged
|
- [ ] Ensure all [the required PRs](https://github.com/vector-im/element-android/pulls?q=is%3Aopen+is%3Apr+label%3AZ-NextRelease) have been merged
|
||||||
|
|
||||||
### Do the release
|
### Do the release
|
||||||
|
|
||||||
- [ ] Run the script ./tools/release/releaseScript.sh and follow the steps.
|
- [ ] Make sure `develop` and `main` are up to date (git pull)
|
||||||
|
- [ ] Checkout develop and create a release with gitflow, branch name `release/1.2.3`
|
||||||
|
- [ ] Check the crashes from the PlayStore
|
||||||
|
- [ ] Check the rageshake with the current dev version: https://github.com/matrix-org/element-android-rageshakes/labels/1.2.3-dev
|
||||||
|
- [ ] Run the integration test, and especially `UiAllScreensSanityTest.allScreensTest()`
|
||||||
|
- [ ] Create an account on matrix.org and do some smoke tests that the sanity test does not cover like: 1-1 call, 1-1 video call, Jitsi call for instance
|
||||||
|
- [ ] Run towncrier: `towncrier build --version v1.2.3 --draft` (remove `--draft` do write the file CHANGES.md)
|
||||||
|
- [ ] Check that the folder `changelog.d` is empty. It can happen that some remaining files stay here
|
||||||
|
- [ ] Check the file CHANGES.md consistency. It's possible to reorder items (most important changes first) or change their section if relevant. Also an opportunity to fix some typo, or rewrite things
|
||||||
|
- [ ] Add file for fastlane under ./fastlane/metadata/android/en-US/changelogs
|
||||||
|
- [ ] (optional) Push the branch and start a draft PR (will not be merged), to check that the CI is happy with all the changes.
|
||||||
|
- [ ] Finish release with gitflow, delete the draft PR (if created)
|
||||||
|
- [ ] Push `main` and the new tag `v1.2.3` to origin
|
||||||
|
- [ ] Checkout `develop`
|
||||||
|
- [ ] Increase version (versionPatch + 2) in `./vector/build.gradle`
|
||||||
|
- [ ] Change the value of SDK_VERSION in the file `./matrix-sdk-android/build.gradle`
|
||||||
|
- [ ] Commit and push `develop`
|
||||||
|
- [ ] Wait for [Buildkite](https://buildkite.com/matrix-dot-org/element-android/builds?branch=main) to build the `main` branch.
|
||||||
|
- [ ] Run the script `~/scripts/releaseElement.sh`. It will download the APKs from Buildkite check them and sign them.
|
||||||
|
- [ ] Install the APK on your phone to check that the upgrade went well (no init sync, etc.)
|
||||||
|
- [ ] Create the release on gitHub [from the tag](https://github.com/vector-im/element-android/tags), copy paste the block from the file CHANGES.md
|
||||||
|
- [ ] Add the 4 signed APKs to the GitHub release
|
||||||
|
- [ ] Ping the Android Internal room
|
||||||
|
|
||||||
### Once tested and validated internally
|
### Once tested and validated internally
|
||||||
|
|
||||||
@ -60,9 +84,29 @@ body:
|
|||||||
|
|
||||||
The SDK2 and the sample app are released only when Element has been pushed to production.
|
The SDK2 and the sample app are released only when Element has been pushed to production.
|
||||||
|
|
||||||
- [ ] On the [SDK2 project](https://github.com/matrix-org/matrix-android-sdk2), run the script ./tools/releaseScript.sh and follow the instructions.
|
- [ ] Checkout the `main` branch on Element Android project
|
||||||
|
|
||||||
Note: if the step `./gradlew closeAndReleaseRepository` fails (for instance, several repositories are waiting to be handled), you have to close and release the repository manually. Do the following steps:
|
#### On the SDK2 project
|
||||||
|
|
||||||
|
https://github.com/matrix-org/matrix-android-sdk2
|
||||||
|
|
||||||
|
- [ ] Create a release with GitFlow
|
||||||
|
- [ ] Update the value of VERSION_NAME in the file gradle.properties
|
||||||
|
- [ ] Update the files `./build.gradle` and `./gradle/gradle-wrapper.properties` manually, to use the latest version for the dependency. You can get inspired by the same files on Element Android project.
|
||||||
|
- [ ] Run the script `./tools/import_from_element.sh`
|
||||||
|
- [ ] Check the diff in the file `./matrix-sdk-android/build.gradle` and restore what may have been erased (in particular the line `apply plugin: "com.vanniktech.maven.publish"` and the line about the version)
|
||||||
|
- [ ] Let the script finish to build the library
|
||||||
|
- [ ] Update the file `CHANGES.md`
|
||||||
|
- [ ] Finish the release using GitFlow
|
||||||
|
- [ ] Push the branch `main`, the new tag and the branch `develop` to origin
|
||||||
|
|
||||||
|
##### Release on MavenCentral
|
||||||
|
|
||||||
|
- [ ] Checkout the branch `main`
|
||||||
|
- [ ] Run the command `./gradlew publish --no-daemon --no-parallel`. You'll need some non-public element to do so
|
||||||
|
- [ ] Run the command `./gradlew closeAndReleaseRepository`. If it is working well, you can jump directly to the final step of this section.
|
||||||
|
|
||||||
|
If `./gradlew closeAndReleaseRepository` fails (for instance, several repositories are waiting to be handled), you have to close and release the repository manually. Do the following steps:
|
||||||
|
|
||||||
- [ ] Connect to https://s01.oss.sonatype.org
|
- [ ] Connect to https://s01.oss.sonatype.org
|
||||||
- [ ] Click on Staging Repositories and check the the files have been uploaded
|
- [ ] Click on Staging Repositories and check the the files have been uploaded
|
||||||
@ -70,6 +114,15 @@ body:
|
|||||||
- [ ] Wait (check Activity tab until step "Repository closed" is displayed)
|
- [ ] Wait (check Activity tab until step "Repository closed" is displayed)
|
||||||
- [ ] Click on release. The staging repository will disappear
|
- [ ] Click on release. The staging repository will disappear
|
||||||
|
|
||||||
|
Final step
|
||||||
|
|
||||||
|
- [ ] Check that the release is available in https://repo1.maven.org/maven2/org/matrix/android/matrix-android-sdk2/ (it can take a few minutes)
|
||||||
|
|
||||||
|
##### Release on GitHub
|
||||||
|
|
||||||
|
- [ ] Create the release on GitHub from [the tag](https://github.com/matrix-org/matrix-android-sdk2/tags)
|
||||||
|
- [ ] Upload the AAR on the GitHub release
|
||||||
|
|
||||||
### Android SDK2 sample
|
### Android SDK2 sample
|
||||||
|
|
||||||
https://github.com/matrix-org/matrix-android-sdk2-sample
|
https://github.com/matrix-org/matrix-android-sdk2-sample
|
||||||
|
92
.github/workflows/build.yml
vendored
92
.github/workflows/build.yml
vendored
@ -1,92 +0,0 @@
|
|||||||
name: APK Build
|
|
||||||
|
|
||||||
on:
|
|
||||||
pull_request: { }
|
|
||||||
push:
|
|
||||||
branches: [ main, develop ]
|
|
||||||
|
|
||||||
# Enrich gradle.properties for CI/CD
|
|
||||||
env:
|
|
||||||
GRADLE_OPTS: -Dorg.gradle.jvmargs="-Xmx3072m -Dfile.encoding=UTF-8 -XX:+HeapDumpOnOutOfMemoryError" -Dkotlin.daemon.jvm.options="-Xmx2560m" -Dkotlin.incremental=false
|
|
||||||
CI_GRADLE_ARG_PROPERTIES: --stacktrace -PpreDexEnable=false --max-workers 2 --no-daemon
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
debug:
|
|
||||||
name: Build debug APKs (${{ matrix.target }})
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: github.ref != 'refs/heads/main'
|
|
||||||
strategy:
|
|
||||||
fail-fast: false
|
|
||||||
matrix:
|
|
||||||
target: [ Gplay, Fdroid ]
|
|
||||||
# Allow all jobs on develop. Just one per PR.
|
|
||||||
concurrency:
|
|
||||||
group: ${{ github.ref == 'refs/heads/develop' && format('integration-tests-develop-{0}-{1}', matrix.target, github.sha) || format('build-debug-{0}-{1}', matrix.target, github.ref) }}
|
|
||||||
cancel-in-progress: true
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v3
|
|
||||||
- uses: actions/cache@v3
|
|
||||||
with:
|
|
||||||
path: |
|
|
||||||
~/.gradle/caches
|
|
||||||
~/.gradle/wrapper
|
|
||||||
key: ${{ runner.os }}-gradle-${{ hashFiles('**/*.gradle*', '**/gradle-wrapper.properties') }}
|
|
||||||
restore-keys: |
|
|
||||||
${{ runner.os }}-gradle-
|
|
||||||
- name: Assemble ${{ matrix.target }} debug apk
|
|
||||||
run: ./gradlew assemble${{ matrix.target }}Debug $CI_GRADLE_ARG_PROPERTIES
|
|
||||||
- name: Upload ${{ matrix.target }} debug APKs
|
|
||||||
uses: actions/upload-artifact@v3
|
|
||||||
with:
|
|
||||||
name: vector-${{ matrix.target }}-debug
|
|
||||||
path: |
|
|
||||||
vector-app/build/outputs/apk/*/debug/*.apk
|
|
||||||
|
|
||||||
release:
|
|
||||||
name: Build unsigned GPlay APKs
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
concurrency:
|
|
||||||
group: ${{ github.ref == 'refs/head/main' && format('build-release-apk-main-{0}', github.sha) || github.ref == 'refs/heads/develop' && format('build-release-apk-develop-{0}', github.sha) || format('build-debug-{0}', github.ref) }}
|
|
||||||
cancel-in-progress: ${{ github.ref != 'refs/head/main' }}
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v3
|
|
||||||
- uses: actions/cache@v3
|
|
||||||
with:
|
|
||||||
path: |
|
|
||||||
~/.gradle/caches
|
|
||||||
~/.gradle/wrapper
|
|
||||||
key: ${{ runner.os }}-gradle-${{ hashFiles('**/*.gradle*', '**/gradle-wrapper.properties') }}
|
|
||||||
restore-keys: |
|
|
||||||
${{ runner.os }}-gradle-
|
|
||||||
- name: Assemble GPlay unsigned apk
|
|
||||||
run: ./gradlew clean assembleGplayRelease $CI_GRADLE_ARG_PROPERTIES
|
|
||||||
- name: Upload Gplay unsigned APKs
|
|
||||||
uses: actions/upload-artifact@v3
|
|
||||||
with:
|
|
||||||
name: vector-gplay-release-unsigned
|
|
||||||
path: |
|
|
||||||
vector-app/build/outputs/apk/*/release/*.apk
|
|
||||||
|
|
||||||
exodus:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
needs: release
|
|
||||||
steps:
|
|
||||||
- name: Obtain apk from artifact
|
|
||||||
id: download
|
|
||||||
uses: actions/download-artifact@v3
|
|
||||||
with:
|
|
||||||
name: vector-gplay-release-unsigned
|
|
||||||
- name: Show apks in artifact
|
|
||||||
run: ls -R ${{steps.download.outputs.download-path}}
|
|
||||||
- name: Execute exodus-standalone
|
|
||||||
uses: docker://exodusprivacy/exodus-standalone:latest
|
|
||||||
with:
|
|
||||||
args: /github/workspace/gplay/release/vector-gplay-universal-release-unsigned.apk -j -o /github/workspace/exodus.json
|
|
||||||
- name: Upload exodus json report
|
|
||||||
uses: actions/upload-artifact@v3
|
|
||||||
with:
|
|
||||||
name: exodus.json
|
|
||||||
path: |
|
|
||||||
exodus.json
|
|
||||||
- name: Check for trackers
|
|
||||||
run: "jq -e '.trackers == []' exodus.json > /dev/null || { echo '::error static analysis identified user tracking library' ; exit 1; }"
|
|
20
.github/workflows/danger.yml
vendored
20
.github/workflows/danger.yml
vendored
@ -1,20 +0,0 @@
|
|||||||
name: Danger CI
|
|
||||||
|
|
||||||
on: [pull_request]
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
name: Danger
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v3
|
|
||||||
- run: |
|
|
||||||
npm install --save-dev @babel/plugin-transform-flow-strip-types
|
|
||||||
- name: Danger
|
|
||||||
uses: danger/danger-js@11.2.0
|
|
||||||
with:
|
|
||||||
args: "--dangerfile ./tools/danger/dangerfile.js"
|
|
||||||
env:
|
|
||||||
DANGER_GITHUB_API_TOKEN: ${{ secrets.DANGER_GITHUB_API_TOKEN }}
|
|
||||||
# Fallback for forks
|
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
22
.github/workflows/docs.yml
vendored
22
.github/workflows/docs.yml
vendored
@ -1,22 +0,0 @@
|
|||||||
name: Documentation
|
|
||||||
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
branches: [ develop ]
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
docs:
|
|
||||||
name: Generate and publish Android Matrix SDK documentation
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- name: Checkout repository
|
|
||||||
uses: actions/checkout@v3
|
|
||||||
|
|
||||||
- name: Build docs
|
|
||||||
run: ./gradlew dokkaHtml
|
|
||||||
|
|
||||||
- name: Deploy docs
|
|
||||||
uses: peaceiris/actions-gh-pages@v3
|
|
||||||
with:
|
|
||||||
github_token: ${{ secrets.GITHUB_TOKEN }}
|
|
||||||
publish_dir: ./matrix-sdk-android/build/dokka/html
|
|
14
.github/workflows/gradle-wrapper-validation.yml
vendored
14
.github/workflows/gradle-wrapper-validation.yml
vendored
@ -1,14 +0,0 @@
|
|||||||
name: "Validate Gradle Wrapper"
|
|
||||||
on:
|
|
||||||
pull_request: { }
|
|
||||||
push:
|
|
||||||
branches: [ main, develop ]
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
validation:
|
|
||||||
name: "Validation"
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
# No concurrency required, this is a prerequisite to other actions and should run every time.
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v3
|
|
||||||
- uses: gradle/wrapper-validation-action@v1
|
|
46
.github/workflows/nightly.yml
vendored
46
.github/workflows/nightly.yml
vendored
@ -1,46 +0,0 @@
|
|||||||
name: Build and release nightly APK
|
|
||||||
|
|
||||||
on:
|
|
||||||
schedule:
|
|
||||||
# Every nights at 4
|
|
||||||
- cron: "0 4 * * *"
|
|
||||||
|
|
||||||
env:
|
|
||||||
GRADLE_OPTS: -Dorg.gradle.jvmargs="-Xmx3072m -Dfile.encoding=UTF-8 -XX:+HeapDumpOnOutOfMemoryError" -Dkotlin.daemon.jvm.options="-Xmx2560m" -Dkotlin.incremental=false
|
|
||||||
CI_GRADLE_ARG_PROPERTIES: --stacktrace -PpreDexEnable=false --max-workers 2 --no-daemon
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
nightly:
|
|
||||||
name: Build and publish nightly Gplay APK to Firebase
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v3
|
|
||||||
- name: Set up Python 3.8
|
|
||||||
uses: actions/setup-python@v4
|
|
||||||
with:
|
|
||||||
python-version: 3.8
|
|
||||||
- uses: actions/cache@v3
|
|
||||||
with:
|
|
||||||
path: |
|
|
||||||
~/.gradle/caches
|
|
||||||
~/.gradle/wrapper
|
|
||||||
key: ${{ runner.os }}-gradle-${{ hashFiles('**/*.gradle*', '**/gradle-wrapper.properties') }}
|
|
||||||
restore-keys: |
|
|
||||||
${{ runner.os }}-gradle-
|
|
||||||
- name: Install towncrier
|
|
||||||
run: |
|
|
||||||
python3 -m pip install towncrier
|
|
||||||
- name: Prepare changelog file
|
|
||||||
run: |
|
|
||||||
mv towncrier.toml towncrier.toml.bak
|
|
||||||
sed 's/CHANGES\.md/CHANGES_NIGHTLY\.md/' towncrier.toml.bak > towncrier.toml
|
|
||||||
rm towncrier.toml.bak
|
|
||||||
yes n | towncrier build --version nightly
|
|
||||||
- name: Build and upload Gplay Nightly APK
|
|
||||||
run: |
|
|
||||||
./gradlew assembleGplayNightly appDistributionUploadGplayNightly $CI_GRADLE_ARG_PROPERTIES
|
|
||||||
env:
|
|
||||||
ELEMENT_ANDROID_NIGHTLY_KEYID: ${{ secrets.ELEMENT_ANDROID_NIGHTLY_KEYID }}
|
|
||||||
ELEMENT_ANDROID_NIGHTLY_KEYPASSWORD: ${{ secrets.ELEMENT_ANDROID_NIGHTLY_KEYPASSWORD }}
|
|
||||||
ELEMENT_ANDROID_NIGHTLY_STOREPASSWORD: ${{ secrets.ELEMENT_ANDROID_NIGHTLY_STOREPASSWORD }}
|
|
||||||
FIREBASE_TOKEN: ${{ secrets.ELEMENT_ANDROID_NIGHTLY_FIREBASE_TOKEN }}
|
|
106
.github/workflows/post-pr.yml
vendored
106
.github/workflows/post-pr.yml
vendored
@ -1,106 +0,0 @@
|
|||||||
name: Integration Tests
|
|
||||||
|
|
||||||
# This runs for all closed pull requests against main, including those closed without merge.
|
|
||||||
# Further filtering occurs in 'should-i-run'
|
|
||||||
|
|
||||||
on:
|
|
||||||
pull_request:
|
|
||||||
types: [closed]
|
|
||||||
branches: [develop]
|
|
||||||
|
|
||||||
# Enrich gradle.properties for CI/CD
|
|
||||||
env:
|
|
||||||
GRADLE_OPTS: -Dorg.gradle.jvmargs="-Xmx3072m -Dfile.encoding=UTF-8 -XX:+HeapDumpOnOutOfMemoryError" -Dkotlin.daemon.jvm.options="-Xmx2560m" -Dkotlin.incremental=false
|
|
||||||
CI_GRADLE_ARG_PROPERTIES: --stacktrace -PpreDexEnable=false --max-workers 2 --no-daemon
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
|
|
||||||
# More info on should-i-run:
|
|
||||||
# If this fails to run (the IF doesn't complete) then the needs will not be satisfied for any of the
|
|
||||||
# other jobs below, so none will run.
|
|
||||||
# except for the notification job at the bottom which will run all the time, unless should-i-run isn't
|
|
||||||
# successful, or all the other jobs have succeeded
|
|
||||||
|
|
||||||
should-i-run:
|
|
||||||
name: Check if PR is suitable for analysis
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: github.event.pull_request.merged # Additionally require PR to have been completely merged.
|
|
||||||
steps:
|
|
||||||
- run: echo "Run those tests!" # no-op success
|
|
||||||
|
|
||||||
ui-tests:
|
|
||||||
name: UI Tests (Synapse)
|
|
||||||
needs: should-i-run
|
|
||||||
runs-on: buildjet-4vcpu-ubuntu-2204
|
|
||||||
timeout-minutes: 90 # We might need to increase it if the time for tests grows
|
|
||||||
strategy:
|
|
||||||
fail-fast: false
|
|
||||||
matrix:
|
|
||||||
api-level: [ 28 ]
|
|
||||||
# No concurrency required, runs every time on a schedule.
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v3
|
|
||||||
- name: Set up Python 3.8
|
|
||||||
uses: actions/setup-python@v4
|
|
||||||
with:
|
|
||||||
python-version: 3.8
|
|
||||||
- uses: actions/cache@v3
|
|
||||||
with:
|
|
||||||
path: |
|
|
||||||
~/.gradle/caches
|
|
||||||
~/.gradle/wrapper
|
|
||||||
key: ${{ runner.os }}-gradle-${{ hashFiles('**/*.gradle*', '**/gradle-wrapper.properties') }}
|
|
||||||
restore-keys: |
|
|
||||||
${{ runner.os }}-gradle-
|
|
||||||
- name: Start synapse server
|
|
||||||
uses: michaelkaye/setup-matrix-synapse@v1.0.4
|
|
||||||
with:
|
|
||||||
uploadLogs: true
|
|
||||||
httpPort: 8080
|
|
||||||
disableRateLimiting: true
|
|
||||||
public_baseurl: "http://10.0.2.2:8080/"
|
|
||||||
- uses: actions/setup-java@v3
|
|
||||||
with:
|
|
||||||
distribution: 'adopt'
|
|
||||||
java-version: '11'
|
|
||||||
- name: Run sanity tests on API ${{ matrix.api-level }}
|
|
||||||
uses: reactivecircus/android-emulator-runner@v2
|
|
||||||
with:
|
|
||||||
api-level: ${{ matrix.api-level }}
|
|
||||||
arch: x86
|
|
||||||
profile: Nexus 5X
|
|
||||||
force-avd-creation: false
|
|
||||||
emulator-options: -no-snapshot-save -no-window -gpu swiftshader_indirect -noaudio -no-boot-anim -camera-back none
|
|
||||||
emulator-build: 7425822 # workaround to emulator bug: https://github.com/ReactiveCircus/android-emulator-runner/issues/160
|
|
||||||
script: |
|
|
||||||
adb root
|
|
||||||
adb logcat -c
|
|
||||||
touch emulator.log
|
|
||||||
chmod 777 emulator.log
|
|
||||||
adb logcat >> emulator.log &
|
|
||||||
./gradlew $CI_GRADLE_ARG_PROPERTIES connectedGplayDebugAndroidTest -Pandroid.testInstrumentationRunnerArguments.class=im.vector.app.ui.UiAllScreensSanityTest || (adb pull storage/emulated/0/Pictures/failure_screenshots && exit 1 )
|
|
||||||
- name: Upload Test Report Log
|
|
||||||
uses: actions/upload-artifact@v3
|
|
||||||
if: always()
|
|
||||||
with:
|
|
||||||
name: uitest-error-results
|
|
||||||
path: |
|
|
||||||
emulator.log
|
|
||||||
failure_screenshots/
|
|
||||||
|
|
||||||
# Notify the channel about delayed failures
|
|
||||||
notify:
|
|
||||||
name: Notify matrix
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
needs:
|
|
||||||
- should-i-run
|
|
||||||
- ui-tests
|
|
||||||
if: always() && (needs.should-i-run.result == 'success' ) && (needs.ui-tests.result != 'success')
|
|
||||||
# No concurrency required, runs every time on a schedule.
|
|
||||||
steps:
|
|
||||||
- uses: michaelkaye/matrix-hookshot-action@v1.0.0
|
|
||||||
with:
|
|
||||||
github_token: ${{ secrets.GITHUB_TOKEN }}
|
|
||||||
hookshot_url: ${{ secrets.ELEMENT_ANDROID_HOOKSHOT_URL }}
|
|
||||||
text_template: "Post-merge validation of ${{ github.head_ref }} into ${{ github.base_ref }} by ${{ github.event.pull_request.merged_by.login }} failed: {{#each job_statuses }}{{#with this }}{{#if completed }} {{name}} {{conclusion}} at {{completed_at}}, {{/if}}{{/with}}{{/each}}"
|
|
||||||
html_template: "Post-merge validation of ${{ github.head_ref }} into ${{ github.base_ref }} by ${{ github.event.pull_request.merged_by.login }} failed: {{#each job_statuses }}{{#with this }}{{#if completed }}<br />{{icon conclusion}} {{name}} <font color='{{color conclusion}}'>{{conclusion}} at {{completed_at}} <a href=\"{{html_url}}\">[details]</a></font>{{/if}}{{/with}}{{/each}}"
|
|
94
.github/workflows/quality.yml
vendored
94
.github/workflows/quality.yml
vendored
@ -1,94 +0,0 @@
|
|||||||
name: Code Quality Checks
|
|
||||||
|
|
||||||
on:
|
|
||||||
pull_request: { }
|
|
||||||
push:
|
|
||||||
branches: [ main, develop ]
|
|
||||||
|
|
||||||
# Enrich gradle.properties for CI/CD
|
|
||||||
env:
|
|
||||||
GRADLE_OPTS: -Dorg.gradle.jvmargs="-Xmx3072m -Dfile.encoding=UTF-8 -XX:+HeapDumpOnOutOfMemoryError" -XX:MaxPermSize=512m -Dkotlin.daemon.jvm.options="-Xmx2g" -Dkotlin.incremental=false
|
|
||||||
CI_GRADLE_ARG_PROPERTIES: --stacktrace -PpreDexEnable=false --max-workers 2 --no-daemon
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
check:
|
|
||||||
name: Project Check Suite
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v3
|
|
||||||
- name: Run code quality check suite
|
|
||||||
run: ./tools/check/check_code_quality.sh
|
|
||||||
|
|
||||||
# Knit for all the modules (https://github.com/Kotlin/kotlinx-knit)
|
|
||||||
knit:
|
|
||||||
name: Knit
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v3
|
|
||||||
- name: Run knit
|
|
||||||
run: |
|
|
||||||
./gradlew knitCheck $CI_GRADLE_ARG_PROPERTIES
|
|
||||||
|
|
||||||
# Check the project: ktlint, detekt, lint
|
|
||||||
lint:
|
|
||||||
name: Android Linter
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
# Allow all jobs on main and develop. Just one per PR.
|
|
||||||
concurrency:
|
|
||||||
group: ${{ github.ref == 'refs/heads/main' && format('lint-main-{0}', github.sha) || github.ref == 'refs/heads/develop' && format('lint-develop-{0}', github.sha) || format('lint-{0}', github.ref) }}
|
|
||||||
cancel-in-progress: true
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v3
|
|
||||||
- name: Run ktlint
|
|
||||||
run: |
|
|
||||||
./gradlew ktlintCheck $CI_GRADLE_ARG_PROPERTIES --continue
|
|
||||||
- name: Run detekt
|
|
||||||
if: always()
|
|
||||||
run: |
|
|
||||||
./gradlew detekt $CI_GRADLE_ARG_PROPERTIES
|
|
||||||
- name: Run lint
|
|
||||||
# Not always, if ktlint or detekt fail, avoid running the long lint check.
|
|
||||||
run: |
|
|
||||||
./gradlew vector-app:lintGplayRelease $CI_GRADLE_ARG_PROPERTIES
|
|
||||||
./gradlew vector-app:lintFdroidRelease $CI_GRADLE_ARG_PROPERTIES
|
|
||||||
- name: Upload reports
|
|
||||||
if: always()
|
|
||||||
uses: actions/upload-artifact@v3
|
|
||||||
with:
|
|
||||||
name: linting-report
|
|
||||||
path: |
|
|
||||||
*/build/reports/**/*.*
|
|
||||||
- name: Prepare Danger
|
|
||||||
if: always()
|
|
||||||
run: |
|
|
||||||
npm install --save-dev @babel/core
|
|
||||||
npm install --save-dev @babel/plugin-transform-flow-strip-types
|
|
||||||
yarn add danger-plugin-lint-report --dev
|
|
||||||
- name: Danger lint
|
|
||||||
if: always()
|
|
||||||
uses: danger/danger-js@11.2.0
|
|
||||||
with:
|
|
||||||
args: "--dangerfile ./tools/danger/dangerfile-lint.js"
|
|
||||||
env:
|
|
||||||
DANGER_GITHUB_API_TOKEN: ${{ secrets.DANGER_GITHUB_API_TOKEN }}
|
|
||||||
# Fallback for forks
|
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
||||||
|
|
||||||
# Gradle dependency analysis using https://github.com/autonomousapps/dependency-analysis-android-gradle-plugin
|
|
||||||
dependency-analysis:
|
|
||||||
name: Dependency analysis
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
# Allow all jobs on main and develop. Just one per PR.
|
|
||||||
concurrency:
|
|
||||||
group: ${{ github.ref == 'refs/heads/main' && format('dep-main-{0}', github.sha) || github.ref == 'refs/heads/develop' && format('dep-develop-{0}', github.sha) || format('dep-{0}', github.ref) }}
|
|
||||||
cancel-in-progress: true
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v3
|
|
||||||
- name: Dependency analysis
|
|
||||||
run: ./gradlew dependencyCheckAnalyze $CI_GRADLE_ARG_PROPERTIES
|
|
||||||
- name: Upload dependency analysis
|
|
||||||
if: always()
|
|
||||||
uses: actions/upload-artifact@v3
|
|
||||||
with:
|
|
||||||
name: dependency-analysis
|
|
||||||
path: build/reports/dependency-check-report.html
|
|
83
.github/workflows/sync-from-external-sources.yml
vendored
83
.github/workflows/sync-from-external-sources.yml
vendored
@ -1,83 +0,0 @@
|
|||||||
name: Sync Data From External Sources
|
|
||||||
on:
|
|
||||||
schedule:
|
|
||||||
# At 00:00 on every Monday UTC
|
|
||||||
- cron: '0 0 * * 1'
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
sync-emojis:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
# Skip in forks
|
|
||||||
if: github.repository == 'vector-im/element-android'
|
|
||||||
# No concurrency required, runs every time on a schedule.
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v3
|
|
||||||
- name: Set up Python 3.8
|
|
||||||
uses: actions/setup-python@v4
|
|
||||||
with:
|
|
||||||
python-version: 3.8
|
|
||||||
- name: Install Prerequisite dependencies
|
|
||||||
run: |
|
|
||||||
pip install BeautifulSoup4
|
|
||||||
pip install requests
|
|
||||||
- name: Run Emoji script
|
|
||||||
run: ./tools/import_emojis.py
|
|
||||||
- name: Create Pull Request for Emojis
|
|
||||||
uses: peter-evans/create-pull-request@v4
|
|
||||||
with:
|
|
||||||
commit-message: Sync Emojis
|
|
||||||
title: Sync Emojis
|
|
||||||
body: |
|
|
||||||
- Update Emojis from Unicode.org
|
|
||||||
branch: sync-emojis
|
|
||||||
base: develop
|
|
||||||
|
|
||||||
sync-sas-strings:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
# Skip in forks
|
|
||||||
if: github.repository == 'vector-im/element-android'
|
|
||||||
# No concurrency required, runs every time on a schedule.
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v3
|
|
||||||
- name: Set up Python 3.8
|
|
||||||
uses: actions/setup-python@v4
|
|
||||||
with:
|
|
||||||
python-version: 3.8
|
|
||||||
- name: Install Prerequisite dependencies
|
|
||||||
run: |
|
|
||||||
pip install requests
|
|
||||||
- name: Run SAS String script
|
|
||||||
run: ./tools/import_sas_strings.py
|
|
||||||
- name: Create Pull Request for SAS Strings
|
|
||||||
uses: peter-evans/create-pull-request@v4
|
|
||||||
with:
|
|
||||||
commit-message: Sync SAS Strings
|
|
||||||
title: Sync SAS Strings
|
|
||||||
body: |
|
|
||||||
- Update SAS Strings from matrix-doc.
|
|
||||||
branch: sync-sas-strings
|
|
||||||
base: develop
|
|
||||||
|
|
||||||
sync-analytics-plan:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
# Skip in forks
|
|
||||||
if: github.repository == 'vector-im/element-android'
|
|
||||||
# No concurrency required, runs every time on a schedule.
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v3
|
|
||||||
- name: Run analytics import script
|
|
||||||
run: ./tools/import_analytic_plan.sh
|
|
||||||
- name: Create Pull Request for analytics plan
|
|
||||||
uses: peter-evans/create-pull-request@v4
|
|
||||||
with:
|
|
||||||
commit-message: Sync analytics plan
|
|
||||||
title: Sync analytics plan
|
|
||||||
body: |
|
|
||||||
### Update analytics plan
|
|
||||||
Reviewers:
|
|
||||||
- [ ] Please remove usage of Event or Enum which may have been removed or updated
|
|
||||||
- [ ] please ensure new Events or new Enums are used to send analytics by pushing new commit(s) to this PR.
|
|
||||||
|
|
||||||
*Note*: Change are coming from [this project](https://github.com/matrix-org/matrix-analytics-events)
|
|
||||||
branch: sync-analytics-plan
|
|
||||||
base: develop
|
|
37
.github/workflows/tester.yml
vendored
Normal file
37
.github/workflows/tester.yml
vendored
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
name: "tests"
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- michaelk/dont_look_now
|
||||||
|
jobs:
|
||||||
|
test:
|
||||||
|
runs-on: buildjet-4vcpu-ubuntu-2204
|
||||||
|
steps:
|
||||||
|
- name: report cpu
|
||||||
|
run: 'echo "INITIAL_CPU=`cat /proc/stat | grep "cpu "`" >> $GITHUB_ENV'
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
- uses: actions/setup-python@v4
|
||||||
|
with:
|
||||||
|
python-version: "3.x"
|
||||||
|
- name: Run synapse
|
||||||
|
uses: michaelkaye/setup-matrix-synapse@v1.0.3
|
||||||
|
with:
|
||||||
|
uploadLogs: true
|
||||||
|
httpPort: 8008
|
||||||
|
customConfig: |
|
||||||
|
registration_shared_secret: RegistrationSharedSecret
|
||||||
|
- name: timed test setup
|
||||||
|
run: synapse/env/bin/pip install -r requirements.txt
|
||||||
|
- name: create user
|
||||||
|
run: synapse/env/bin/register_new_matrix_user -u tester -p password --no-admin -k RegistrationSharedSecret http://localhost:8008
|
||||||
|
- name: timed One
|
||||||
|
run: synapse/env/bin/python ./timed_test.py
|
||||||
|
- name: timed Two
|
||||||
|
run: synapse/env/bin/python ./timed_test.py
|
||||||
|
- name: timed Three
|
||||||
|
run: synapse/env/bin/python ./timed_test.py
|
||||||
|
- name: timed Four
|
||||||
|
run: synapse/env/bin/python ./timed_test.py
|
||||||
|
- name: report cpu after
|
||||||
|
run: "./eval_cpu.sh"
|
||||||
|
|
152
.github/workflows/tests.yml
vendored
152
.github/workflows/tests.yml
vendored
@ -1,152 +0,0 @@
|
|||||||
name: Test
|
|
||||||
|
|
||||||
on:
|
|
||||||
pull_request: { }
|
|
||||||
push:
|
|
||||||
branches: [ main, develop ]
|
|
||||||
|
|
||||||
# Enrich gradle.properties for CI/CD
|
|
||||||
env:
|
|
||||||
GRADLE_OPTS: -Dorg.gradle.jvmargs="-Xmx3072m -Dfile.encoding=UTF-8 -XX:+HeapDumpOnOutOfMemoryError" -Dkotlin.daemon.jvm.options="-Xmx2560m" -Dkotlin.incremental=false
|
|
||||||
CI_GRADLE_ARG_PROPERTIES: --stacktrace -PpreDexEnable=false --max-workers 4 --no-daemon
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
tests:
|
|
||||||
name: Runs all tests
|
|
||||||
runs-on: buildjet-4vcpu-ubuntu-2204
|
|
||||||
timeout-minutes: 90 # We might need to increase it if the time for tests grows
|
|
||||||
strategy:
|
|
||||||
matrix:
|
|
||||||
api-level: [28]
|
|
||||||
# Allow all jobs on main and develop. Just one per PR.
|
|
||||||
concurrency:
|
|
||||||
group: ${{ github.ref == 'refs/heads/main' && format('unit-tests-main-{0}', github.sha) || github.ref == 'refs/heads/develop' && format('unit-tests-develop-{0}', github.sha) || format('unit-tests-{0}', github.ref) }}
|
|
||||||
cancel-in-progress: true
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v3
|
|
||||||
with:
|
|
||||||
lfs: true
|
|
||||||
fetch-depth: 0
|
|
||||||
- uses: actions/setup-java@v3
|
|
||||||
with:
|
|
||||||
distribution: 'adopt'
|
|
||||||
java-version: '11'
|
|
||||||
- uses: gradle/gradle-build-action@v2
|
|
||||||
with:
|
|
||||||
cache-read-only: ${{ github.ref != 'refs/heads/develop' }}
|
|
||||||
gradle-home-cache-cleanup: ${{ github.ref == 'refs/heads/develop' }}
|
|
||||||
|
|
||||||
- name: Run screenshot tests
|
|
||||||
run: ./gradlew verifyScreenshots $CI_GRADLE_ARG_PROPERTIES
|
|
||||||
|
|
||||||
- name: Archive Screenshot Results on Error
|
|
||||||
if: failure()
|
|
||||||
uses: actions/upload-artifact@v3
|
|
||||||
with:
|
|
||||||
name: screenshot-results
|
|
||||||
path: |
|
|
||||||
**/out/failures/
|
|
||||||
**/build/reports/tests/*UnitTest/
|
|
||||||
|
|
||||||
- uses: actions/setup-python@v4
|
|
||||||
with:
|
|
||||||
python-version: 3.8
|
|
||||||
- uses: michaelkaye/setup-matrix-synapse@v1.0.4
|
|
||||||
with:
|
|
||||||
uploadLogs: true
|
|
||||||
httpPort: 8080
|
|
||||||
disableRateLimiting: true
|
|
||||||
public_baseurl: "http://10.0.2.2:8080/"
|
|
||||||
|
|
||||||
- name: Run all the codecoverage tests at once
|
|
||||||
uses: reactivecircus/android-emulator-runner@v2
|
|
||||||
# continue-on-error: true
|
|
||||||
with:
|
|
||||||
api-level: ${{ matrix.api-level }}
|
|
||||||
arch: x86
|
|
||||||
profile: Nexus 5X
|
|
||||||
target: playstore
|
|
||||||
force-avd-creation: false
|
|
||||||
emulator-options: -no-snapshot-save -no-window -gpu swiftshader_indirect -noaudio -no-boot-anim -camera-back none
|
|
||||||
disable-animations: true
|
|
||||||
# emulator-build: 7425822
|
|
||||||
script: |
|
|
||||||
./gradlew gatherGplayDebugStringTemplates $CI_GRADLE_ARG_PROPERTIES
|
|
||||||
./gradlew unitTestsWithCoverage $CI_GRADLE_ARG_PROPERTIES
|
|
||||||
./gradlew instrumentationTestsWithCoverage $CI_GRADLE_ARG_PROPERTIES
|
|
||||||
./gradlew generateCoverageReport $CI_GRADLE_ARG_PROPERTIES
|
|
||||||
# NB: continue-on-error marks steps.tests.conclusion = 'success' but leaves steps.tests.outcome = 'failure'
|
|
||||||
### - name: Run all the codecoverage tests at once (retry if emulator failed)
|
|
||||||
### uses: reactivecircus/android-emulator-runner@v2
|
|
||||||
### if: always() && steps.tests.outcome == 'failure' # don't run if previous step succeeded.
|
|
||||||
### with:
|
|
||||||
### api-level: 28
|
|
||||||
### arch: x86
|
|
||||||
### profile: Nexus 5X
|
|
||||||
### force-avd-creation: false
|
|
||||||
### emulator-options: -no-snapshot-save -no-window -gpu swiftshader_indirect -noaudio -no-boot-anim -camera-back none
|
|
||||||
### disable-animations: true
|
|
||||||
### emulator-build: 7425822
|
|
||||||
### script: |
|
|
||||||
### ./gradlew gatherGplayDebugStringTemplates $CI_GRADLE_ARG_PROPERTIES
|
|
||||||
### ./gradlew unitTestsWithCoverage $CI_GRADLE_ARG_PROPERTIES
|
|
||||||
### ./gradlew instrumentationTestsWithCoverage $CI_GRADLE_ARG_PROPERTIES
|
|
||||||
### ./gradlew generateCoverageReport $CI_GRADLE_ARG_PROPERTIES
|
|
||||||
|
|
||||||
- name: Upload Integration Test Report Log
|
|
||||||
uses: actions/upload-artifact@v3
|
|
||||||
if: always()
|
|
||||||
with:
|
|
||||||
name: integration-test-error-results
|
|
||||||
path: |
|
|
||||||
*/build/outputs/androidTest-results/connected/
|
|
||||||
*/build/reports/androidTests/connected/
|
|
||||||
|
|
||||||
# we may have failed a previous step and retried, that's OK
|
|
||||||
- name: Publish results to Sonar
|
|
||||||
env:
|
|
||||||
GITHUB_TOKEN: ${{ secrets.SONARQUBE_GITHUB_API_TOKEN }} # Needed to get PR information, if any
|
|
||||||
SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }}
|
|
||||||
ORG_GRADLE_PROJECT_SONAR_LOGIN: ${{ secrets.SONAR_TOKEN }}
|
|
||||||
if: ${{ always() && env.GITHUB_TOKEN != '' && env.SONAR_TOKEN != '' && env.ORG_GRADLE_PROJECT_SONAR_LOGIN != '' }}
|
|
||||||
run: ./gradlew sonarqube $CI_GRADLE_ARG_PROPERTIES
|
|
||||||
|
|
||||||
- name: Format unit test results
|
|
||||||
if: always()
|
|
||||||
run: python3 ./tools/ci/render_test_output.py unit ./**/build/test-results/**/*.xml
|
|
||||||
|
|
||||||
# can't be run on macos due to containers.
|
|
||||||
# - name: Publish Unit Test Results
|
|
||||||
# uses: EnricoMi/publish-unit-test-result-action@v1
|
|
||||||
# if: always() &&
|
|
||||||
# github.event.sender.login != 'dependabot[bot]' &&
|
|
||||||
# ( github.event_name != 'pull_request' || github.event.pull_request.head.repo.full_name == github.repository )
|
|
||||||
# with:
|
|
||||||
# files: ./**/build/test-results/**/*.xml
|
|
||||||
|
|
||||||
# Unneeded as part of the test suite above, kept around in case we want to re-enable them.
|
|
||||||
#
|
|
||||||
# # Build Android Tests
|
|
||||||
# build-android-tests:
|
|
||||||
# name: Build Android Tests
|
|
||||||
# runs-on: ubuntu-latest
|
|
||||||
# concurrency:
|
|
||||||
# group: ${{ github.ref == 'refs/heads/main' && format('unit-tests-main-{0}', github.sha) || github.ref == 'refs/heads/develop' && format('unit-tests-develop-{0}', github.sha) || format('build-android-tests-{0}', github.ref) }}
|
|
||||||
# cancel-in-progress: true
|
|
||||||
# steps:
|
|
||||||
# - uses: actions/checkout@v3
|
|
||||||
# - uses: actions/setup-java@v3
|
|
||||||
# with:
|
|
||||||
# distribution: 'adopt'
|
|
||||||
# java-version: 11
|
|
||||||
# - uses: actions/cache@v3
|
|
||||||
# with:
|
|
||||||
# path: |
|
|
||||||
# ~/.gradle/caches
|
|
||||||
# ~/.gradle/wrapper
|
|
||||||
# key: ${{ runner.os }}-gradle-${{ hashFiles('**/*.gradle*', '**/gradle-wrapper.properties') }}
|
|
||||||
# restore-keys: |
|
|
||||||
# ${{ runner.os }}-gradle-
|
|
||||||
# - name: Build Android Tests
|
|
||||||
# run: ./gradlew clean assembleAndroidTest $CI_GRADLE_ARG_PROPERTIES
|
|
||||||
|
|
17
.github/workflows/triage-incoming.yml
vendored
17
.github/workflows/triage-incoming.yml
vendored
@ -1,17 +0,0 @@
|
|||||||
name: Move new issues onto Issue triage board
|
|
||||||
|
|
||||||
on:
|
|
||||||
issues:
|
|
||||||
types: [opened]
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
automate-project-columns:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
# Skip in forks
|
|
||||||
if: github.repository == 'vector-im/element-android'
|
|
||||||
steps:
|
|
||||||
- uses: alex-page/github-project-automation-plus@1f8873e97e3c8f58161a323b7c568c1f623a1c4d
|
|
||||||
with:
|
|
||||||
project: Issue triage
|
|
||||||
column: Incoming
|
|
||||||
repo-token: ${{ secrets.ELEMENT_BOT_TOKEN }}
|
|
374
.github/workflows/triage-labelled.yml
vendored
374
.github/workflows/triage-labelled.yml
vendored
@ -1,374 +0,0 @@
|
|||||||
name: Move labelled issues to correct boards and columns
|
|
||||||
|
|
||||||
on:
|
|
||||||
issues:
|
|
||||||
types: [labeled]
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
apply_Z-Labs_label:
|
|
||||||
name: Add Z-Labs label for features behind labs flags
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: >
|
|
||||||
contains(github.event.issue.labels.*.name, 'A-Maths') ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'A-Message-Pinning') ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'A-Polls') ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'A-Location-Sharing') ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'A-Message-Bubbles') ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'Z-IA') ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'A-Themes-Custom') ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'A-E2EE-Dehydration') ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'A-Tags') ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'A-Rich-Text-Editor')
|
|
||||||
steps:
|
|
||||||
- uses: actions/github-script@v5
|
|
||||||
with:
|
|
||||||
script: |
|
|
||||||
github.rest.issues.addLabels({
|
|
||||||
issue_number: context.issue.number,
|
|
||||||
owner: context.repo.owner,
|
|
||||||
repo: context.repo.repo,
|
|
||||||
labels: ['Z-Labs']
|
|
||||||
})
|
|
||||||
|
|
||||||
apply_Help-Wanted_label:
|
|
||||||
name: Add "Help Wanted" label to all "good first issue" and Hacktoberfest
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: >
|
|
||||||
contains(github.event.issue.labels.*.name, 'good first issue') ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'Hacktoberfest')
|
|
||||||
steps:
|
|
||||||
- uses: actions/github-script@v5
|
|
||||||
with:
|
|
||||||
script: |
|
|
||||||
github.rest.issues.addLabels({
|
|
||||||
issue_number: context.issue.number,
|
|
||||||
owner: context.repo.owner,
|
|
||||||
repo: context.repo.repo,
|
|
||||||
labels: ['Help Wanted']
|
|
||||||
})
|
|
||||||
|
|
||||||
move_needs_info_issues:
|
|
||||||
name: X-Needs-Info issues to Need info column on triage board
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
# Skip in forks
|
|
||||||
if: github.repository == 'vector-im/element-android'
|
|
||||||
steps:
|
|
||||||
- uses: konradpabjan/move-labeled-or-milestoned-issue@219d384e03fa4b6460cd24f9f37d19eb033a4338
|
|
||||||
with:
|
|
||||||
action-token: "${{ secrets.ELEMENT_BOT_TOKEN }}"
|
|
||||||
project-url: "https://github.com/vector-im/element-android/projects/4"
|
|
||||||
column-name: "Need info"
|
|
||||||
label-name: "X-Needs-Info"
|
|
||||||
|
|
||||||
add_design_issues_to_project:
|
|
||||||
name: X-Needs-Design to Design project board
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
# Skip in forks
|
|
||||||
if: >
|
|
||||||
github.repository == 'vector-im/element-android' &&
|
|
||||||
contains(github.event.issue.labels.*.name, 'X-Needs-Design') &&
|
|
||||||
(contains(github.event.issue.labels.*.name, 'S-Critical') &&
|
|
||||||
(contains(github.event.issue.labels.*.name, 'O-Frequent') ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'O-Occasional')) ||
|
|
||||||
(contains(github.event.issue.labels.*.name, 'S-Major') &&
|
|
||||||
contains(github.event.issue.labels.*.name, 'O-Frequent')) ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'A11y'))
|
|
||||||
steps:
|
|
||||||
- uses: octokit/graphql-action@v2.x
|
|
||||||
id: add_to_project
|
|
||||||
with:
|
|
||||||
headers: '{"GraphQL-Features": "projects_next_graphql"}'
|
|
||||||
query: |
|
|
||||||
mutation add_to_project($projectid:ID!,$contentid:ID!) {
|
|
||||||
addProjectV2ItemById(input: {projectId: $projectid contentId: $contentid}) {
|
|
||||||
item {
|
|
||||||
id
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
projectid: ${{ env.PROJECT_ID }}
|
|
||||||
contentid: ${{ github.event.issue.node_id }}
|
|
||||||
env:
|
|
||||||
PROJECT_ID: "PVT_kwDOAM0swc0sUA"
|
|
||||||
GITHUB_TOKEN: ${{ secrets.ELEMENT_BOT_TOKEN }}
|
|
||||||
|
|
||||||
add_product_issues:
|
|
||||||
name: X-Needs-Product to Design project board
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: >
|
|
||||||
contains(github.event.issue.labels.*.name, 'X-Needs-Product')
|
|
||||||
steps:
|
|
||||||
- uses: octokit/graphql-action@v2.x
|
|
||||||
id: add_to_project
|
|
||||||
with:
|
|
||||||
headers: '{"GraphQL-Features": "projects_next_graphql"}'
|
|
||||||
query: |
|
|
||||||
mutation add_to_project($projectid:ID!,$contentid:ID!) {
|
|
||||||
addProjectV2ItemById(input: {projectId: $projectid contentId: $contentid}) {
|
|
||||||
item {
|
|
||||||
id
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
projectid: ${{ env.PROJECT_ID }}
|
|
||||||
contentid: ${{ github.event.issue.node_id }}
|
|
||||||
env:
|
|
||||||
PROJECT_ID: "PVT_kwDOAM0swc4AAg6N"
|
|
||||||
GITHUB_TOKEN: ${{ secrets.ELEMENT_BOT_TOKEN }}
|
|
||||||
|
|
||||||
delight_issues_to_board:
|
|
||||||
name: Spaces issues to Delight project board
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
# Skip in forks
|
|
||||||
if: >
|
|
||||||
github.repository == 'vector-im/element-android' &&
|
|
||||||
(contains(github.event.issue.labels.*.name, 'Team: Delight') ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'Z-AppLayout'))
|
|
||||||
steps:
|
|
||||||
- uses: octokit/graphql-action@v2.x
|
|
||||||
with:
|
|
||||||
headers: '{"GraphQL-Features": "projects_next_graphql"}'
|
|
||||||
query: |
|
|
||||||
mutation add_to_project($projectid:ID!,$contentid:ID!) {
|
|
||||||
addProjectV2ItemById(input: {projectId: $projectid contentId: $contentid}) {
|
|
||||||
item {
|
|
||||||
id
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
projectid: ${{ env.PROJECT_ID }}
|
|
||||||
contentid: ${{ github.event.issue.node_id }}
|
|
||||||
env:
|
|
||||||
PROJECT_ID: "PVT_kwDOAM0swc1HvQ"
|
|
||||||
GITHUB_TOKEN: ${{ secrets.ELEMENT_BOT_TOKEN }}
|
|
||||||
|
|
||||||
move_voice-message_issues:
|
|
||||||
name: A-Voice Messages to voice message board
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
# Skip in forks
|
|
||||||
if: >
|
|
||||||
github.repository == 'vector-im/element-android' &&
|
|
||||||
contains(github.event.issue.labels.*.name, 'A-Voice Messages')
|
|
||||||
steps:
|
|
||||||
- uses: octokit/graphql-action@v2.x
|
|
||||||
with:
|
|
||||||
headers: '{"GraphQL-Features": "projects_next_graphql"}'
|
|
||||||
query: |
|
|
||||||
mutation add_to_project($projectid:ID!,$contentid:ID!) {
|
|
||||||
addProjectV2ItemById(input: {projectId: $projectid contentId: $contentid}) {
|
|
||||||
item {
|
|
||||||
id
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
projectid: ${{ env.PROJECT_ID }}
|
|
||||||
contentid: ${{ github.event.issue.node_id }}
|
|
||||||
env:
|
|
||||||
PROJECT_ID: "PVT_kwDOAM0swc2KCw"
|
|
||||||
GITHUB_TOKEN: ${{ secrets.ELEMENT_BOT_TOKEN }}
|
|
||||||
move_message_bubbles_issues:
|
|
||||||
name: A-Message-Bubbles to Message bubbles board
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
# Skip in forks
|
|
||||||
if: >
|
|
||||||
github.repository == 'vector-im/element-android' &&
|
|
||||||
contains(github.event.issue.labels.*.name, 'A-Message-Bubbles')
|
|
||||||
steps:
|
|
||||||
- uses: octokit/graphql-action@v2.x
|
|
||||||
with:
|
|
||||||
headers: '{"GraphQL-Features": "projects_next_graphql"}'
|
|
||||||
query: |
|
|
||||||
mutation add_to_project($projectid:ID!,$contentid:ID!) {
|
|
||||||
addProjectV2ItemById(input: {projectId: $projectid contentId: $contentid}) {
|
|
||||||
item {
|
|
||||||
id
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
projectid: ${{ env.PROJECT_ID }}
|
|
||||||
contentid: ${{ github.event.issue.node_id }}
|
|
||||||
env:
|
|
||||||
PROJECT_ID: "PVT_kwDOAM0swc3m-g"
|
|
||||||
GITHUB_TOKEN: ${{ secrets.ELEMENT_BOT_TOKEN }}
|
|
||||||
|
|
||||||
move_ftue_issues:
|
|
||||||
name: Z-FTUE to Mobile FTUE board
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
# Skip in forks
|
|
||||||
if: >
|
|
||||||
github.repository == 'vector-im/element-android' &&
|
|
||||||
contains(github.event.issue.labels.*.name, 'Z-FTUE')
|
|
||||||
steps:
|
|
||||||
- uses: octokit/graphql-action@v2.x
|
|
||||||
with:
|
|
||||||
headers: '{"GraphQL-Features": "projects_next_graphql"}'
|
|
||||||
query: |
|
|
||||||
mutation add_to_project($projectid:ID!,$contentid:ID!) {
|
|
||||||
addProjectV2ItemById(input: {projectId: $projectid contentId: $contentid}) {
|
|
||||||
item {
|
|
||||||
id
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
projectid: ${{ env.PROJECT_ID }}
|
|
||||||
contentid: ${{ github.event.issue.node_id }}
|
|
||||||
env:
|
|
||||||
PROJECT_ID: "PVT_kwDOAM0swc4AAqVx"
|
|
||||||
GITHUB_TOKEN: ${{ secrets.ELEMENT_BOT_TOKEN }}
|
|
||||||
|
|
||||||
move_WTF_issues:
|
|
||||||
name: Z-WTF to WTF board
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
# Skip in forks
|
|
||||||
if: >
|
|
||||||
github.repository == 'vector-im/element-android' &&
|
|
||||||
contains(github.event.issue.labels.*.name, 'Z-WTF')
|
|
||||||
steps:
|
|
||||||
- uses: octokit/graphql-action@v2.x
|
|
||||||
with:
|
|
||||||
headers: '{"GraphQL-Features": "projects_next_graphql"}'
|
|
||||||
query: |
|
|
||||||
mutation add_to_project($projectid:ID!,$contentid:ID!) {
|
|
||||||
addProjectV2ItemById(input: {projectId: $projectid contentId: $contentid}) {
|
|
||||||
item {
|
|
||||||
id
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
projectid: ${{ env.PROJECT_ID }}
|
|
||||||
contentid: ${{ github.event.issue.node_id }}
|
|
||||||
env:
|
|
||||||
PROJECT_ID: "PVT_kwDOAM0swc4AArk0"
|
|
||||||
GITHUB_TOKEN: ${{ secrets.ELEMENT_BOT_TOKEN }}
|
|
||||||
|
|
||||||
move_element_x_issues:
|
|
||||||
name: ElementX issues to ElementX project board
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
# Skip in forks
|
|
||||||
if: >
|
|
||||||
github.repository == 'vector-im/element-android' &&
|
|
||||||
(contains(github.event.issue.labels.*.name, 'Z-BBQ-Alpha') ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'Z-BBQ-Beta') ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'Z-BBQ-Release') ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'Z-Banquet-Alpha') ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'Z-Banquet-Beta') ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'Z-Banquet-Release'))
|
|
||||||
steps:
|
|
||||||
- uses: octokit/graphql-action@v2.x
|
|
||||||
with:
|
|
||||||
headers: '{"GraphQL-Features": "projects_next_graphql"}'
|
|
||||||
query: |
|
|
||||||
mutation add_to_project($projectid:ID!,$contentid:ID!) {
|
|
||||||
addProjectV2ItemById(input: {projectId: $projectid contentId: $contentid}) {
|
|
||||||
item {
|
|
||||||
id
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
projectid: ${{ env.PROJECT_ID }}
|
|
||||||
contentid: ${{ github.event.issue.node_id }}
|
|
||||||
env:
|
|
||||||
PROJECT_ID: "PVT_kwDOAM0swc4ABTXY"
|
|
||||||
GITHUB_TOKEN: ${{ secrets.ELEMENT_BOT_TOKEN }}
|
|
||||||
|
|
||||||
ps_features1:
|
|
||||||
name: Add labelled issues to PS features team 1
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: >
|
|
||||||
contains(github.event.issue.labels.*.name, 'A-Polls') ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'A-Location-Sharing') ||
|
|
||||||
(contains(github.event.issue.labels.*.name, 'A-Voice-Messages') &&
|
|
||||||
!contains(github.event.issue.labels.*.name, 'A-Broadcast')) ||
|
|
||||||
(contains(github.event.issue.labels.*.name, 'A-Session-Mgmt') &&
|
|
||||||
contains(github.event.issue.labels.*.name, 'A-User-Settings'))
|
|
||||||
steps:
|
|
||||||
- uses: octokit/graphql-action@v2.x
|
|
||||||
id: add_to_project
|
|
||||||
with:
|
|
||||||
headers: '{"GraphQL-Features": "projects_next_graphql"}'
|
|
||||||
query: |
|
|
||||||
mutation add_to_project($projectid:ID!,$contentid:ID!) {
|
|
||||||
addProjectV2ItemById(input: {projectId: $projectid contentId: $contentid}) {
|
|
||||||
item {
|
|
||||||
id
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
projectid: ${{ env.PROJECT_ID }}
|
|
||||||
contentid: ${{ github.event.issue.node_id }}
|
|
||||||
env:
|
|
||||||
PROJECT_ID: "PVT_kwDOAM0swc4AHJKF"
|
|
||||||
GITHUB_TOKEN: ${{ secrets.ELEMENT_BOT_TOKEN }}
|
|
||||||
|
|
||||||
ps_features2:
|
|
||||||
name: Add labelled issues to PS features team 2
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: >
|
|
||||||
contains(github.event.issue.labels.*.name, 'A-DM-Start') ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'A-Broadcast')
|
|
||||||
steps:
|
|
||||||
- uses: octokit/graphql-action@v2.x
|
|
||||||
id: add_to_project
|
|
||||||
with:
|
|
||||||
headers: '{"GraphQL-Features": "projects_next_graphql"}'
|
|
||||||
query: |
|
|
||||||
mutation add_to_project($projectid:ID!,$contentid:ID!) {
|
|
||||||
addProjectV2ItemById(input: {projectId: $projectid contentId: $contentid}) {
|
|
||||||
item {
|
|
||||||
id
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
projectid: ${{ env.PROJECT_ID }}
|
|
||||||
contentid: ${{ github.event.issue.node_id }}
|
|
||||||
env:
|
|
||||||
PROJECT_ID: "PVT_kwDOAM0swc4AHJKd"
|
|
||||||
GITHUB_TOKEN: ${{ secrets.ELEMENT_BOT_TOKEN }}
|
|
||||||
|
|
||||||
ps_features3:
|
|
||||||
name: Add labelled issues to PS features team 3
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: >
|
|
||||||
contains(github.event.issue.labels.*.name, 'A-Rich-Text-Editor')
|
|
||||||
steps:
|
|
||||||
- uses: octokit/graphql-action@v2.x
|
|
||||||
id: add_to_project
|
|
||||||
with:
|
|
||||||
headers: '{"GraphQL-Features": "projects_next_graphql"}'
|
|
||||||
query: |
|
|
||||||
mutation add_to_project($projectid:ID!,$contentid:ID!) {
|
|
||||||
addProjectV2ItemById(input: {projectId: $projectid contentId: $contentid}) {
|
|
||||||
item {
|
|
||||||
id
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
projectid: ${{ env.PROJECT_ID }}
|
|
||||||
contentid: ${{ github.event.issue.node_id }}
|
|
||||||
env:
|
|
||||||
PROJECT_ID: "PVT_kwDOAM0swc4AHJKW"
|
|
||||||
GITHUB_TOKEN: ${{ secrets.ELEMENT_BOT_TOKEN }}
|
|
||||||
|
|
||||||
voip:
|
|
||||||
name: Add labelled issues to VoIP project board
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: >
|
|
||||||
contains(github.event.issue.labels.*.name, 'Team: VoIP')
|
|
||||||
steps:
|
|
||||||
- uses: octokit/graphql-action@v2.x
|
|
||||||
id: add_to_project
|
|
||||||
with:
|
|
||||||
headers: '{"GraphQL-Features": "projects_next_graphql"}'
|
|
||||||
query: |
|
|
||||||
mutation add_to_project($projectid:ID!,$contentid:ID!) {
|
|
||||||
addProjectV2ItemById(input: {projectId: $projectid contentId: $contentid}) {
|
|
||||||
item {
|
|
||||||
id
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
projectid: ${{ env.PROJECT_ID }}
|
|
||||||
contentid: ${{ github.event.issue.node_id }}
|
|
||||||
env:
|
|
||||||
PROJECT_ID: "PVT_kwDOAM0swc4ABMIk"
|
|
||||||
GITHUB_TOKEN: ${{ secrets.ELEMENT_BOT_TOKEN }}
|
|
143
.github/workflows/triage-move-review-requests.yml
vendored
143
.github/workflows/triage-move-review-requests.yml
vendored
@ -1,143 +0,0 @@
|
|||||||
name: Move pull requests asking for review to the relevant project
|
|
||||||
on:
|
|
||||||
pull_request_target:
|
|
||||||
types: [review_requested]
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
add_design_pr_to_project:
|
|
||||||
name: Move PRs asking for design review to the design board
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
# Skip in forks
|
|
||||||
if: github.repository == 'vector-im/element-android'
|
|
||||||
steps:
|
|
||||||
- uses: octokit/graphql-action@v2.x
|
|
||||||
id: find_team_members
|
|
||||||
with:
|
|
||||||
headers: '{"GraphQL-Features": "projects_next_graphql"}'
|
|
||||||
query: |
|
|
||||||
query find_team_members($team: String!) {
|
|
||||||
organization(login: "vector-im") {
|
|
||||||
team(slug: $team) {
|
|
||||||
members {
|
|
||||||
nodes {
|
|
||||||
login
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
team: ${{ env.TEAM }}
|
|
||||||
env:
|
|
||||||
TEAM: "design"
|
|
||||||
GITHUB_TOKEN: ${{ secrets.ELEMENT_BOT_TOKEN }}
|
|
||||||
- id: any_matching_reviewers
|
|
||||||
run: |
|
|
||||||
# Fetch requested reviewers, and people who are on the team
|
|
||||||
echo '${{ tojson(fromjson(steps.find_team_members.outputs.data).organization.team.members.nodes[*].login) }}' | tee /tmp/team_members.json
|
|
||||||
echo '${{ tojson(github.event.pull_request.requested_reviewers[*].login) }}' | tee /tmp/reviewers.json
|
|
||||||
jq --raw-output .[] < /tmp/team_members.json | sort | tee /tmp/team_members.txt
|
|
||||||
jq --raw-output .[] < /tmp/reviewers.json | sort | tee /tmp/reviewers.txt
|
|
||||||
|
|
||||||
# Fetch requested team reviewers, and the name of the team
|
|
||||||
echo '${{ tojson(github.event.pull_request.requested_teams[*].slug) }}' | tee /tmp/team_reviewers.json
|
|
||||||
jq --raw-output .[] < /tmp/team_reviewers.json | sort | tee /tmp/team_reviewers.txt
|
|
||||||
echo '${{ env.TEAM }}' | tee /tmp/team.txt
|
|
||||||
|
|
||||||
# If either a reviewer matches a team member, or a team matches our team, say "true"
|
|
||||||
if [ $(join /tmp/team_members.txt /tmp/reviewers.txt | wc -l) != 0 ]; then
|
|
||||||
echo "::set-output name=match::true"
|
|
||||||
elif [ $(join /tmp/team.txt /tmp/team_reviewers.txt | wc -l) != 0 ]; then
|
|
||||||
echo "::set-output name=match::true"
|
|
||||||
else
|
|
||||||
echo "::set-output name=match::false"
|
|
||||||
fi
|
|
||||||
env:
|
|
||||||
TEAM: "design"
|
|
||||||
- uses: octokit/graphql-action@v2.x
|
|
||||||
id: add_to_project
|
|
||||||
if: steps.any_matching_reviewers.outputs.match == 'true'
|
|
||||||
with:
|
|
||||||
headers: '{"GraphQL-Features": "projects_next_graphql"}'
|
|
||||||
query: |
|
|
||||||
mutation add_to_project($projectid:ID!, $contentid:ID!) {
|
|
||||||
addProjectV2ItemById(input: {projectId: $projectid contentId: $contentid}) {
|
|
||||||
item {
|
|
||||||
id
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
projectid: ${{ env.PROJECT_ID }}
|
|
||||||
contentid: ${{ github.event.pull_request.node_id }}
|
|
||||||
env:
|
|
||||||
PROJECT_ID: "PVT_kwDOAM0swc0sUA"
|
|
||||||
TEAM: "design"
|
|
||||||
GITHUB_TOKEN: ${{ secrets.ELEMENT_BOT_TOKEN }}
|
|
||||||
|
|
||||||
add_product_pr_to_project:
|
|
||||||
name: Move PRs asking for product review to the product board
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
# Skip in forks
|
|
||||||
if: github.repository == 'vector-im/element-android'
|
|
||||||
steps:
|
|
||||||
- uses: octokit/graphql-action@v2.x
|
|
||||||
id: find_team_members
|
|
||||||
with:
|
|
||||||
headers: '{"GraphQL-Features": "projects_next_graphql"}'
|
|
||||||
query: |
|
|
||||||
query find_team_members($team: String!) {
|
|
||||||
organization(login: "vector-im") {
|
|
||||||
team(slug: $team) {
|
|
||||||
members {
|
|
||||||
nodes {
|
|
||||||
login
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
team: ${{ env.TEAM }}
|
|
||||||
env:
|
|
||||||
TEAM: "product"
|
|
||||||
GITHUB_TOKEN: ${{ secrets.ELEMENT_BOT_TOKEN }}
|
|
||||||
- id: any_matching_reviewers
|
|
||||||
run: |
|
|
||||||
# Fetch requested reviewers, and people who are on the team
|
|
||||||
echo '${{ tojson(fromjson(steps.find_team_members.outputs.data).organization.team.members.nodes[*].login) }}' | tee /tmp/team_members.json
|
|
||||||
echo '${{ tojson(github.event.pull_request.requested_reviewers[*].login) }}' | tee /tmp/reviewers.json
|
|
||||||
jq --raw-output .[] < /tmp/team_members.json | sort | tee /tmp/team_members.txt
|
|
||||||
jq --raw-output .[] < /tmp/reviewers.json | sort | tee /tmp/reviewers.txt
|
|
||||||
|
|
||||||
# Fetch requested team reviewers, and the name of the team
|
|
||||||
echo '${{ tojson(github.event.pull_request.requested_teams[*].slug) }}' | tee /tmp/team_reviewers.json
|
|
||||||
jq --raw-output .[] < /tmp/team_reviewers.json | sort | tee /tmp/team_reviewers.txt
|
|
||||||
echo '${{ env.TEAM }}' | tee /tmp/team.txt
|
|
||||||
|
|
||||||
# If either a reviewer matches a team member, or a team matches our team, say "true"
|
|
||||||
if [ $(join /tmp/team_members.txt /tmp/reviewers.txt | wc -l) != 0 ]; then
|
|
||||||
echo "::set-output name=match::true"
|
|
||||||
elif [ $(join /tmp/team.txt /tmp/team_reviewers.txt | wc -l) != 0 ]; then
|
|
||||||
echo "::set-output name=match::true"
|
|
||||||
else
|
|
||||||
echo "::set-output name=match::false"
|
|
||||||
fi
|
|
||||||
env:
|
|
||||||
TEAM: "product"
|
|
||||||
- uses: octokit/graphql-action@v2.x
|
|
||||||
id: add_to_project
|
|
||||||
if: steps.any_matching_reviewers.outputs.match == 'true'
|
|
||||||
with:
|
|
||||||
headers: '{"GraphQL-Features": "projects_next_graphql"}'
|
|
||||||
query: |
|
|
||||||
mutation add_to_project($projectid:ID!, $contentid:ID!) {
|
|
||||||
addProjectV2ItemById(input: {projectId: $projectid contentId: $contentid}) {
|
|
||||||
item {
|
|
||||||
id
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
projectid: ${{ env.PROJECT_ID }}
|
|
||||||
contentid: ${{ github.event.pull_request.node_id }}
|
|
||||||
env:
|
|
||||||
PROJECT_ID: "PVT_kwDOAM0swc4AAg6N"
|
|
||||||
TEAM: "product"
|
|
||||||
GITHUB_TOKEN: ${{ secrets.ELEMENT_BOT_TOKEN }}
|
|
57
.github/workflows/triage-priority-bugs.yml
vendored
57
.github/workflows/triage-priority-bugs.yml
vendored
@ -1,57 +0,0 @@
|
|||||||
name: Move P1 bugs to boards
|
|
||||||
|
|
||||||
on:
|
|
||||||
issues:
|
|
||||||
types: [labeled, unlabeled]
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
p1_issues_to_team_workboard:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
# Skip in forks
|
|
||||||
if: >
|
|
||||||
github.repository == 'vector-im/element-android' &&
|
|
||||||
(!contains(github.event.issue.labels.*.name, 'A-E2EE') &&
|
|
||||||
!contains(github.event.issue.labels.*.name, 'A-E2EE-Cross-Signing') &&
|
|
||||||
!contains(github.event.issue.labels.*.name, 'A-E2EE-Dehydration') &&
|
|
||||||
!contains(github.event.issue.labels.*.name, 'A-E2EE-Key-Backup') &&
|
|
||||||
!contains(github.event.issue.labels.*.name, 'A-E2EE-SAS-Verification')) &&
|
|
||||||
(contains(github.event.issue.labels.*.name, 'T-Defect') &&
|
|
||||||
contains(github.event.issue.labels.*.name, 'S-Critical') &&
|
|
||||||
(contains(github.event.issue.labels.*.name, 'O-Frequent') ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'O-Occasional')) ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'S-Major') &&
|
|
||||||
contains(github.event.issue.labels.*.name, 'O-Frequent') ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'A11y') &&
|
|
||||||
contains(github.event.issue.labels.*.name, 'O-Frequent'))
|
|
||||||
steps:
|
|
||||||
- uses: alex-page/github-project-automation-plus@1f8873e97e3c8f58161a323b7c568c1f623a1c4d
|
|
||||||
with:
|
|
||||||
project: Android App Team
|
|
||||||
column: Important Issues & Topics (P1)
|
|
||||||
repo-token: ${{ secrets.ELEMENT_BOT_TOKEN }}
|
|
||||||
|
|
||||||
P1_issues_to_crypto_team_workboard:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
# Skip in forks
|
|
||||||
if: >
|
|
||||||
github.repository == 'vector-im/element-android' &&
|
|
||||||
(contains(github.event.issue.labels.*.name, 'Z-UISI') ||
|
|
||||||
(contains(github.event.issue.labels.*.name, 'A-E2EE') ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'A-E2EE-Cross-Signing') ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'A-E2EE-Dehydration') ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'A-E2EE-Key-Backup') ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'A-E2EE-SAS-Verification')) &&
|
|
||||||
(contains(github.event.issue.labels.*.name, 'T-Defect') &&
|
|
||||||
contains(github.event.issue.labels.*.name, 'S-Critical') &&
|
|
||||||
(contains(github.event.issue.labels.*.name, 'O-Frequent') ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'O-Occasional')) ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'S-Major') &&
|
|
||||||
contains(github.event.issue.labels.*.name, 'O-Frequent') ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'A11y') &&
|
|
||||||
contains(github.event.issue.labels.*.name, 'O-Frequent')))
|
|
||||||
steps:
|
|
||||||
- uses: alex-page/github-project-automation-plus@1f8873e97e3c8f58161a323b7c568c1f623a1c4d
|
|
||||||
with:
|
|
||||||
project: Crypto Team
|
|
||||||
column: Ready
|
|
||||||
repo-token: ${{ secrets.ELEMENT_BOT_TOKEN }}
|
|
62
.github/workflows/triage-unlabelled.yml
vendored
62
.github/workflows/triage-unlabelled.yml
vendored
@ -1,62 +0,0 @@
|
|||||||
name: Move unlabelled from needs info columns to triaged
|
|
||||||
|
|
||||||
on:
|
|
||||||
issues:
|
|
||||||
types: [unlabeled]
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
Move_Unabeled_Issue_On_Project_Board:
|
|
||||||
name: Move no longer X-Needs-Info issues to Triaged
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
# Skip in forks
|
|
||||||
if: >
|
|
||||||
github.repository == 'vector-im/element-android' &&
|
|
||||||
!contains(github.event.issue.labels.*.name, 'X-Needs-Info')
|
|
||||||
env:
|
|
||||||
BOARD_NAME: "Issue triage"
|
|
||||||
OWNER: ${{ github.repository_owner }}
|
|
||||||
REPO: ${{ github.event.repository.name }}
|
|
||||||
ISSUE: ${{ github.event.issue.number }}
|
|
||||||
steps:
|
|
||||||
- name: Check if issue is already in "${{ env.BOARD_NAME }}"
|
|
||||||
run: |
|
|
||||||
if curl -i -H 'Content-Type: application/json' -H "Authorization: bearer ${{ secrets.GITHUB_TOKEN }}" -X POST -d '{"query": "query($issue: Int!, $owner: String!, $repo: String!) { repository(owner: $owner, name: $repo) { issue(number: $issue) { projectCards { nodes { project { name } } } } } } ", "variables" : "{ \"issue\": '${ISSUE}', \"owner\": \"'${OWNER}'\", \"repo\": \"'${REPO}'\" }" }' https://api.github.com/graphql | grep "\b$BOARD_NAME\b"; then
|
|
||||||
echo "Issue is already in Project '$BOARD_NAME', proceeding";
|
|
||||||
echo "ALREADY_IN_BOARD=true" >> $GITHUB_ENV
|
|
||||||
else
|
|
||||||
echo "Issue is not in project '$BOARD_NAME', cancelling this workflow"
|
|
||||||
echo "ALREADY_IN_BOARD=false" >> $GITHUB_ENV
|
|
||||||
fi
|
|
||||||
- name: Move issue
|
|
||||||
uses: alex-page/github-project-automation-plus@1f8873e97e3c8f58161a323b7c568c1f623a1c4d
|
|
||||||
if: ${{ env.ALREADY_IN_BOARD == 'true' }}
|
|
||||||
with:
|
|
||||||
project: Issue triage
|
|
||||||
column: Triaged
|
|
||||||
repo-token: ${{ secrets.ELEMENT_BOT_TOKEN }}
|
|
||||||
|
|
||||||
remove_Z-Labs_label:
|
|
||||||
name: Remove Z-Labs label when features behind labs flags are removed
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
if: >
|
|
||||||
!(contains(github.event.issue.labels.*.name, 'A-Maths') ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'A-Message-Pinning') ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'A-Threads') ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'A-Polls') ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'A-Location-Sharing') ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'A-Message-Bubbles') ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'Z-IA') ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'A-Themes-Custom') ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'A-E2EE-Dehydration') ||
|
|
||||||
contains(github.event.issue.labels.*.name, 'A-Tags')) &&
|
|
||||||
contains(github.event.issue.labels.*.name, 'Z-Labs')
|
|
||||||
steps:
|
|
||||||
- uses: actions/github-script@v5
|
|
||||||
with:
|
|
||||||
script: |
|
|
||||||
github.rest.issues.removeLabel({
|
|
||||||
issue_number: context.issue.number,
|
|
||||||
owner: context.repo.owner,
|
|
||||||
repo: context.repo.repo,
|
|
||||||
name: ['Z-Labs']
|
|
||||||
})
|
|
20
.github/workflows/update-gradle-wrapper.yml
vendored
20
.github/workflows/update-gradle-wrapper.yml
vendored
@ -1,20 +0,0 @@
|
|||||||
name: Update Gradle Wrapper
|
|
||||||
|
|
||||||
on:
|
|
||||||
schedule:
|
|
||||||
- cron: "0 0 * * *"
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
update-gradle-wrapper:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v3
|
|
||||||
|
|
||||||
- name: Update Gradle Wrapper
|
|
||||||
uses: gradle-update/update-gradle-wrapper-action@v1
|
|
||||||
# Skip in forks
|
|
||||||
if: github.repository == 'vector-im/element-android'
|
|
||||||
with:
|
|
||||||
repo-token: ${{ secrets.GITHUB_TOKEN }}
|
|
||||||
target-branch: develop
|
|
15
.github/workflows/validate-lfs.yml
vendored
15
.github/workflows/validate-lfs.yml
vendored
@ -1,15 +0,0 @@
|
|||||||
name: Validate Git LFS
|
|
||||||
|
|
||||||
on: [pull_request]
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
name: Validate
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v3
|
|
||||||
with:
|
|
||||||
lfs: 'true'
|
|
||||||
|
|
||||||
- run: |
|
|
||||||
./tools/validate_lfs.sh
|
|
293
CHANGES.md
293
CHANGES.md
@ -1,296 +1,3 @@
|
|||||||
Changes in Element v1.5.18 (2023-01-02)
|
|
||||||
=======================================
|
|
||||||
|
|
||||||
This release fixes a bunch of recent regressions. Most of them were not pushed to production hopefully. Current production version is 1.5.11.
|
|
||||||
Threads are now enabled by default, and this may let the application perform an initial sync.
|
|
||||||
Testers on the PlayStore may have experimented some issues like empty room list, or incomplete room state (room name missing, etc.), or even crashing due to initial sync not using lazy loading of room members. All those issues have been fixed, but to fix your current state, please clear cache once you get the release 1.5.18.
|
|
||||||
|
|
||||||
Bugfixes 🐛
|
|
||||||
----------
|
|
||||||
- Start DM will create a deadlock if user profile was never loaded ([#7870](https://github.com/vector-im/element-android/issues/7870))
|
|
||||||
|
|
||||||
|
|
||||||
Changes in Element v1.5.16 (2022-12-29)
|
|
||||||
======================================
|
|
||||||
|
|
||||||
Features ✨
|
|
||||||
----------
|
|
||||||
- [Rich text editor] Add support for links ([#7746](https://github.com/vector-im/element-android/issues/7746))
|
|
||||||
- [Poll] When a poll is ended, use /relations API to ensure poll results are correct ([#7767](https://github.com/vector-im/element-android/issues/7767))
|
|
||||||
- [Session manager] Security recommendations cards: whole view should be tappable ([#7795](https://github.com/vector-im/element-android/issues/7795))
|
|
||||||
- [Session manager] Other sessions list: header should not be sticky ([#7797](https://github.com/vector-im/element-android/issues/7797))
|
|
||||||
|
|
||||||
Bugfixes 🐛
|
|
||||||
----------
|
|
||||||
- Do not show typing notification of ignored users. ([#2965](https://github.com/vector-im/element-android/issues/2965))
|
|
||||||
- [Push Notifications, Threads] - quick reply to threaded notification now sent to thread except main timeline ([#7475](https://github.com/vector-im/element-android/issues/7475))
|
|
||||||
- [Session manager] Other sessions list: filter option is displayed when selection mode is enabled ([#7784](https://github.com/vector-im/element-android/issues/7784))
|
|
||||||
- [Session manager] Other sessions: Filter bottom sheet cut in landscape mode ([#7786](https://github.com/vector-im/element-android/issues/7786))
|
|
||||||
- Automatically show keyboard after learn more bottom sheet is dismissed ([#7790](https://github.com/vector-im/element-android/issues/7790))
|
|
||||||
- [Session Manager] Other sessions list: cannot select/deselect session by a long press when in select mode ([#7792](https://github.com/vector-im/element-android/issues/7792))
|
|
||||||
- Fix current session ip address visibility ([#7794](https://github.com/vector-im/element-android/issues/7794))
|
|
||||||
- Device Manager UI review fixes ([#7798](https://github.com/vector-im/element-android/issues/7798))
|
|
||||||
|
|
||||||
SDK API changes ⚠️
|
|
||||||
------------------
|
|
||||||
- [Sync] Sync Filter params are moved to MatrixConfiguration and will not be stored in session realm to avoid bug when session cache is cleared ([#7843](https://github.com/vector-im/element-android/issues/7843))
|
|
||||||
|
|
||||||
Other changes
|
|
||||||
-------------
|
|
||||||
- [Voice Broadcast] Replace the player timeline ([#7821](https://github.com/vector-im/element-android/issues/7821))
|
|
||||||
- Increase session manager test coverage ([#7836](https://github.com/vector-im/element-android/issues/7836))
|
|
||||||
|
|
||||||
|
|
||||||
Changes in Element v1.5.14 (2022-12-20)
|
|
||||||
=======================================
|
|
||||||
|
|
||||||
Bugfixes 🐛
|
|
||||||
----------
|
|
||||||
- ActiveSessionHolder is not supposed to start syncing. Instead, the MainActivity does it, if necessary. Fixes a race condition when clearing cache.
|
|
||||||
|
|
||||||
|
|
||||||
Changes in Element v1.5.13 (2022-12-19)
|
|
||||||
=======================================
|
|
||||||
|
|
||||||
Bugfixes 🐛
|
|
||||||
----------
|
|
||||||
- Add `largeHeap=true` in the manifest since we are seeing more crashes (OOM) when handling sync response.
|
|
||||||
|
|
||||||
|
|
||||||
Changes in Element v1.5.12 (2022-12-15)
|
|
||||||
=======================================
|
|
||||||
|
|
||||||
Features ✨
|
|
||||||
----------
|
|
||||||
- [Threads] - Threads Labs Flag is enabled by default and forced to be enabled for existing users, but sill can be disabled manually ([#5503](https://github.com/vector-im/element-android/issues/5503))
|
|
||||||
- [Session manager] Add action to signout all the other session ([#7693](https://github.com/vector-im/element-android/issues/7693))
|
|
||||||
- Remind unverified sessions with a banner once a week ([#7694](https://github.com/vector-im/element-android/issues/7694))
|
|
||||||
- [Session manager] Add actions to rename and signout current session ([#7697](https://github.com/vector-im/element-android/issues/7697))
|
|
||||||
- Voice Broadcast - Update last message in the room list ([#7719](https://github.com/vector-im/element-android/issues/7719))
|
|
||||||
- Delete unused client information from account data ([#7754](https://github.com/vector-im/element-android/issues/7754))
|
|
||||||
|
|
||||||
Bugfixes 🐛
|
|
||||||
----------
|
|
||||||
- Fix bad pills color background. For light and dark theme the color is now 61708B (iso EleWeb) ([#7274](https://github.com/vector-im/element-android/issues/7274))
|
|
||||||
- [Notifications] Fixed a bug when push notification was automatically dismissed while app is on background ([#7643](https://github.com/vector-im/element-android/issues/7643))
|
|
||||||
- ANR when asking to select the notification method ([#7653](https://github.com/vector-im/element-android/issues/7653))
|
|
||||||
- [Rich text editor] Fix design and spacing of rich text editor ([#7658](https://github.com/vector-im/element-android/issues/7658))
|
|
||||||
- [Rich text editor] Fix keyboard closing after collapsing editor ([#7659](https://github.com/vector-im/element-android/issues/7659))
|
|
||||||
- Rich Text Editor: fix several issues related to insets:
|
|
||||||
* Empty space displayed at the bottom when you don't have permissions to send messages into a room.
|
|
||||||
* Wrong insets being kept when you exit the room screen and the keyboard is displayed, then come back to it. ([#7680](https://github.com/vector-im/element-android/issues/7680))
|
|
||||||
- Fix crash in message composer when room is missing ([#7683](https://github.com/vector-im/element-android/issues/7683))
|
|
||||||
- Fix crash when invalid homeserver url is entered. ([#7684](https://github.com/vector-im/element-android/issues/7684))
|
|
||||||
- Rich Text Editor: improve performance when entering reply/edit/quote mode. ([#7691](https://github.com/vector-im/element-android/issues/7691))
|
|
||||||
- [Rich text editor] Add error tracking for rich text editor ([#7695](https://github.com/vector-im/element-android/issues/7695))
|
|
||||||
- Fix E2EE set up failure whilst signing in using QR code ([#7699](https://github.com/vector-im/element-android/issues/7699))
|
|
||||||
- Fix usage of unknown shield in room summary ([#7710](https://github.com/vector-im/element-android/issues/7710))
|
|
||||||
- Fix crash when the network is not available. ([#7725](https://github.com/vector-im/element-android/issues/7725))
|
|
||||||
- [Session manager] Sessions without encryption support should not prompt to verify ([#7733](https://github.com/vector-im/element-android/issues/7733))
|
|
||||||
- Fix issue of Scan QR code button sometimes not showing when it should be available ([#7737](https://github.com/vector-im/element-android/issues/7737))
|
|
||||||
- Verification request is not showing when verify session popup is displayed ([#7743](https://github.com/vector-im/element-android/issues/7743))
|
|
||||||
- Fix crash when inviting by email. ([#7744](https://github.com/vector-im/element-android/issues/7744))
|
|
||||||
- Revert usage of stable fields in live location sharing and polls ([#7751](https://github.com/vector-im/element-android/issues/7751))
|
|
||||||
- [Poll] Poll end event is not recognized ([#7753](https://github.com/vector-im/element-android/issues/7753))
|
|
||||||
- [Push Notifications] When push notification for threaded message is clicked, thread timeline will be opened instead of room's main timeline ([#7770](https://github.com/vector-im/element-android/issues/7770))
|
|
||||||
|
|
||||||
Other changes
|
|
||||||
-------------
|
|
||||||
- [Threads] - added API to fetch threads list from the server instead of building it locally from events ([#5819](https://github.com/vector-im/element-android/issues/5819))
|
|
||||||
- Add Z-Labs label for rich text editor and migrate to new label naming. ([#7477](https://github.com/vector-im/element-android/issues/7477))
|
|
||||||
- Crypto database migration tests ([#7645](https://github.com/vector-im/element-android/issues/7645))
|
|
||||||
- Add tracing Id for to device messages ([#7708](https://github.com/vector-im/element-android/issues/7708))
|
|
||||||
- Disable nightly popup and add an entry point in the advanced settings instead. ([#7723](https://github.com/vector-im/element-android/issues/7723))
|
|
||||||
- Save m.local_notification_settings.<device-id> event in account_data ([#7596](https://github.com/vector-im/element-android/issues/7596))
|
|
||||||
- Update notifications setting when m.local_notification_settings.<device-id> event changes for current device ([#7632](https://github.com/vector-im/element-android/issues/7632))
|
|
||||||
|
|
||||||
SDK API changes ⚠️
|
|
||||||
------------------
|
|
||||||
- Handle account data removal ([#7740](https://github.com/vector-im/element-android/issues/7740))
|
|
||||||
|
|
||||||
Changes in Element 1.5.11 (2022-12-07)
|
|
||||||
======================================
|
|
||||||
|
|
||||||
Bugfixes 🐛
|
|
||||||
----------
|
|
||||||
- Fix crash when the network is not available. ([#7725](https://github.com/vector-im/element-android/issues/7725))
|
|
||||||
|
|
||||||
|
|
||||||
Changes in Element v1.5.10 (2022-11-30)
|
|
||||||
=======================================
|
|
||||||
|
|
||||||
Features ✨
|
|
||||||
----------
|
|
||||||
- Add setting to allow disabling direct share ([#2725](https://github.com/vector-im/element-android/issues/2725))
|
|
||||||
- [Device Manager] Toggle IP address visibility ([#7546](https://github.com/vector-im/element-android/issues/7546))
|
|
||||||
- New implementation of the full screen mode for the Rich Text Editor. ([#7577](https://github.com/vector-im/element-android/issues/7577))
|
|
||||||
|
|
||||||
Bugfixes 🐛
|
|
||||||
----------
|
|
||||||
- Fix italic text is truncated when bubble mode and markdown is enabled ([#5679](https://github.com/vector-im/element-android/issues/5679))
|
|
||||||
- Missing translations on "replyTo" messages ([#7555](https://github.com/vector-im/element-android/issues/7555))
|
|
||||||
- ANR on session start when sending client info is enabled ([#7604](https://github.com/vector-im/element-android/issues/7604))
|
|
||||||
- Make the plain text mode layout of the RTE more compact. ([#7620](https://github.com/vector-im/element-android/issues/7620))
|
|
||||||
- Push notification for thread message is now shown correctly when user observes rooms main timeline ([#7634](https://github.com/vector-im/element-android/issues/7634))
|
|
||||||
- Voice Broadcast - Fix playback stuck in buffering mode ([#7646](https://github.com/vector-im/element-android/issues/7646))
|
|
||||||
|
|
||||||
In development 🚧
|
|
||||||
----------------
|
|
||||||
- Voice Broadcast - Handle redaction of the state events on the listener and recorder sides ([#7629](https://github.com/vector-im/element-android/issues/7629))
|
|
||||||
- Voice Broadcast - Update the buffering display in the timeline ([#7655](https://github.com/vector-im/element-android/issues/7655))
|
|
||||||
- Voice Broadcast - Remove voice messages related to a VB from the room attachments ([#7656](https://github.com/vector-im/element-android/issues/7656))
|
|
||||||
|
|
||||||
SDK API changes ⚠️
|
|
||||||
------------------
|
|
||||||
- Added support for read receipts in threads. Now user in a room can have multiple read receipts (one per thread + one in main thread + one without threadId) ([#6996](https://github.com/vector-im/element-android/issues/6996))
|
|
||||||
- Sync Filter now taking in account homeserver capabilities to not pass unsupported parameters.
|
|
||||||
Sync Filter is now configured by providing SyncFilterBuilder class instance, instead of Filter to identify Filter changes related to homeserver capabilities ([#7626](https://github.com/vector-im/element-android/issues/7626))
|
|
||||||
|
|
||||||
Other changes
|
|
||||||
-------------
|
|
||||||
- Remove usage of Buildkite. ([#7583](https://github.com/vector-im/element-android/issues/7583))
|
|
||||||
- Better validation of edits ([#7594](https://github.com/vector-im/element-android/issues/7594))
|
|
||||||
|
|
||||||
|
|
||||||
Changes in Element v1.5.8 (2022-11-17)
|
|
||||||
======================================
|
|
||||||
|
|
||||||
Features ✨
|
|
||||||
----------
|
|
||||||
- [Session manager] Multi-session signout ([#7418](https://github.com/vector-im/element-android/issues/7418))
|
|
||||||
- Rich text editor: add full screen mode. ([#7436](https://github.com/vector-im/element-android/issues/7436))
|
|
||||||
- [Rich text editor] Add plain text mode ([#7452](https://github.com/vector-im/element-android/issues/7452))
|
|
||||||
- Move TypingView inside the timeline items. ([#7496](https://github.com/vector-im/element-android/issues/7496))
|
|
||||||
- Push notifications toggle: align implementation for current session ([#7512](https://github.com/vector-im/element-android/issues/7512))
|
|
||||||
- Voice messages - Persist the playback position across different screens ([#7582](https://github.com/vector-im/element-android/issues/7582))
|
|
||||||
|
|
||||||
Bugfixes 🐛
|
|
||||||
----------
|
|
||||||
- [Voice Broadcast] Do not display the recorder view for a live broadcast started from another session ([#7431](https://github.com/vector-im/element-android/issues/7431))
|
|
||||||
- [Session manager] Hide push notification toggle when there is no server support ([#7457](https://github.com/vector-im/element-android/issues/7457))
|
|
||||||
- Fix rich text editor textfield not growing to fill parent on full screen. ([#7491](https://github.com/vector-im/element-android/issues/7491))
|
|
||||||
- Fix duplicated mention pills in some cases ([#7501](https://github.com/vector-im/element-android/issues/7501))
|
|
||||||
- Voice Broadcast - Fix duplicated voice messages in the internal playlist ([#7502](https://github.com/vector-im/element-android/issues/7502))
|
|
||||||
- When joining a room, the message composer is displayed once the room is loaded. ([#7509](https://github.com/vector-im/element-android/issues/7509))
|
|
||||||
- Voice Broadcast - Fix error on voice messages in unencrypted rooms ([#7519](https://github.com/vector-im/element-android/issues/7519))
|
|
||||||
- Fix description of verified sessions ([#7533](https://github.com/vector-im/element-android/issues/7533))
|
|
||||||
|
|
||||||
In development 🚧
|
|
||||||
----------------
|
|
||||||
- [Voice Broadcast] Improve timeline items factory and handle bad recording state display ([#7448](https://github.com/vector-im/element-android/issues/7448))
|
|
||||||
- [Voice Broadcast] Stop recording when opening the room after an app restart ([#7450](https://github.com/vector-im/element-android/issues/7450))
|
|
||||||
- [Voice Broadcast] Improve playlist fetching and player codebase ([#7478](https://github.com/vector-im/element-android/issues/7478))
|
|
||||||
- [Voice Broadcast] Display an error dialog if the user fails to start a voice broadcast ([#7485](https://github.com/vector-im/element-android/issues/7485))
|
|
||||||
- [Voice Broadcast] Add seekbar in listening tile ([#7496](https://github.com/vector-im/element-android/issues/7496))
|
|
||||||
- [Voice Broadcast] Improve the live indicator icon rendering in the timeline ([#7579](https://github.com/vector-im/element-android/issues/7579))
|
|
||||||
- Voice Broadcast - Add maximum length ([#7588](https://github.com/vector-im/element-android/issues/7588))
|
|
||||||
|
|
||||||
SDK API changes ⚠️
|
|
||||||
------------------
|
|
||||||
- [Metrics] Add `SpannableMetricPlugin` to support spans within transactions. ([#7514](https://github.com/vector-im/element-android/issues/7514))
|
|
||||||
- Fix a bug that caused messages with no formatted text to be quoted as "null". ([#7530](https://github.com/vector-im/element-android/issues/7530))
|
|
||||||
- If message content has no `formattedBody`, default to `body` when editing. ([#7574](https://github.com/vector-im/element-android/issues/7574))
|
|
||||||
|
|
||||||
|
|
||||||
Changes in Element v1.5.7 (2022-11-07)
|
|
||||||
======================================
|
|
||||||
|
|
||||||
Bugfixes 🐛
|
|
||||||
----------
|
|
||||||
- Fix regression when syncing with homeserver < 1.4. ([#7534](https://github.com/vector-im/element-android/issues/7534))
|
|
||||||
|
|
||||||
Changes in Element v1.5.6 (2022-11-02)
|
|
||||||
======================================
|
|
||||||
|
|
||||||
Features ✨
|
|
||||||
----------
|
|
||||||
- Add new UI for selecting an attachment ([#7429](https://github.com/vector-im/element-android/issues/7429))
|
|
||||||
- Multi selection in sessions list ([#7396](https://github.com/vector-im/element-android/issues/7396))
|
|
||||||
|
|
||||||
Bugfixes 🐛
|
|
||||||
----------
|
|
||||||
- New line and Enter hardware key presses deleting existing text in some keyboards. ([#7357](https://github.com/vector-im/element-android/issues/7357))
|
|
||||||
- Fix share actions using share dialog. ([#7400](https://github.com/vector-im/element-android/issues/7400))
|
|
||||||
- Fix crash by disabling Flipper on Android API 22 and below - only affects debug version of the application. ([#7428](https://github.com/vector-im/element-android/issues/7428))
|
|
||||||
|
|
||||||
In development 🚧
|
|
||||||
----------------
|
|
||||||
- [Voice Broadcast] Live listening support ([#7419](https://github.com/vector-im/element-android/issues/7419))
|
|
||||||
- [Voice Broadcast] Improve rendering in the timeline ([#7421](https://github.com/vector-im/element-android/issues/7421))
|
|
||||||
- Add logic for sign in with QR code ([#7369](https://github.com/vector-im/element-android/issues/7369))
|
|
||||||
|
|
||||||
SDK API changes ⚠️
|
|
||||||
------------------
|
|
||||||
- Add MetricPlugin interface to implement metrics in SDK clients. ([#7438](https://github.com/vector-im/element-android/issues/7438))
|
|
||||||
|
|
||||||
Other changes
|
|
||||||
-------------
|
|
||||||
- Upgrade Jitsi SDK to 6.2.2 and WebRtc to 1.106.1-jitsi-12039821. ([#6195](https://github.com/vector-im/element-android/issues/6195))
|
|
||||||
- Gets thread notifications from sync response ([#7424](https://github.com/vector-im/element-android/issues/7424))
|
|
||||||
- Replace org.apache.sanselan:sanselan by org.apache.commons:commons-imaging ([#7454](https://github.com/vector-im/element-android/issues/7454))
|
|
||||||
|
|
||||||
|
|
||||||
Changes in Element v1.5.4 (2022-10-19)
|
|
||||||
======================================
|
|
||||||
|
|
||||||
Features ✨
|
|
||||||
----------
|
|
||||||
- Add WYSIWYG editor, under a lab flag. ([#7288](https://github.com/vector-im/element-android/issues/7288))
|
|
||||||
- New Device management, can be enabled in the labs settings.
|
|
||||||
- Voice broadcast can be enabled in the labs settings (recording is possible only on Android 10 and up).
|
|
||||||
|
|
||||||
Bugfixes 🐛
|
|
||||||
----------
|
|
||||||
- Fix wrong mic button direction to cancel on RTL languages ([#5968](https://github.com/vector-im/element-android/issues/5968))
|
|
||||||
- Handle properly when getUser returns null - prefer using getUserOrDefault ([#7372](https://github.com/vector-im/element-android/issues/7372))
|
|
||||||
- [Device Management] Long session names not handled well ([#7310](https://github.com/vector-im/element-android/issues/7310))
|
|
||||||
- Fix editing formatted messages with plain text editor ([#7359](https://github.com/vector-im/element-android/issues/7359))
|
|
||||||
|
|
||||||
In development 🚧
|
|
||||||
----------------
|
|
||||||
- [Device Management] Save "matrix_client_information" events on login/registration ([#7257](https://github.com/vector-im/element-android/issues/7257))
|
|
||||||
- [Device management] Add lab flag for the feature ([#7336](https://github.com/vector-im/element-android/issues/7336))
|
|
||||||
- [Device management] Add lab flag for matrix client info account data event ([#7344](https://github.com/vector-im/element-android/issues/7344))
|
|
||||||
- [Device Management] Redirect to the new screen everywhere when lab flag is on ([#7374](https://github.com/vector-im/element-android/issues/7374))
|
|
||||||
- [Device Management] Show correct device type icons ([#7277](https://github.com/vector-im/element-android/issues/7277))
|
|
||||||
- [Device Management] Render extended device info ([#7294](https://github.com/vector-im/element-android/issues/7294))
|
|
||||||
- [Device management] Improve the parsing for OS of Desktop/Web sessions ([#7321](https://github.com/vector-im/element-android/issues/7321))
|
|
||||||
- [Device management] Hide the IP address and last activity date on current session ([#7324](https://github.com/vector-im/element-android/issues/7324))
|
|
||||||
- [Device management] Update the unknown verification status icon ([#7327](https://github.com/vector-im/element-android/issues/7327))
|
|
||||||
- [Voice Broadcast] Add the "io.element.voice_broadcast_info" state event with a minimalist timeline widget ([#7273](https://github.com/vector-im/element-android/issues/7273))
|
|
||||||
- [Voice Broadcast] Aggregate state events in the timeline ([#7283](https://github.com/vector-im/element-android/issues/7283))
|
|
||||||
- [Voice Broadcast] Record and send non aggregated voice messages to the room ([#7363](https://github.com/vector-im/element-android/issues/7363))
|
|
||||||
- [Voice Broadcast] Start listening to a voice broadcast ([#7387](https://github.com/vector-im/element-android/issues/7387))
|
|
||||||
- [Voice Broadcast] Enable the feature (behind a lab flag and only for Android 10 and up) ([#7393](https://github.com/vector-im/element-android/issues/7393))
|
|
||||||
- [Voice Broadcast] Add additional data in events ([#7397](https://github.com/vector-im/element-android/issues/7397))
|
|
||||||
- Implements MSC3881: Parses `enabled` and `device_id` fields from updated Pusher API ([#7217](https://github.com/vector-im/element-android/issues/7217))
|
|
||||||
- Adds pusher toggle setting to device manager v2 ([#7261](https://github.com/vector-im/element-android/issues/7261))
|
|
||||||
- Implement QR Code Login UI ([#7338](https://github.com/vector-im/element-android/issues/7338))
|
|
||||||
- Implements client-side of local notification settings event ([#7300](https://github.com/vector-im/element-android/issues/7300))
|
|
||||||
- Links "Enable Notifications for this session" setting to enabled value in pusher ([#7281](https://github.com/vector-im/element-android/issues/7281))
|
|
||||||
|
|
||||||
SDK API changes ⚠️
|
|
||||||
------------------
|
|
||||||
- Stop using `original_event` field from `/relations` endpoint ([#7282](https://github.com/vector-im/element-android/issues/7282))
|
|
||||||
- Add `formattedText` or similar optional parameters in several methods:
|
|
||||||
* RelationService:
|
|
||||||
* editTextMessage
|
|
||||||
* editReply
|
|
||||||
* replyToMessage
|
|
||||||
* SendService:
|
|
||||||
* sendQuotedTextMessage
|
|
||||||
This allows us to send any HTML formatted text message without needing to rely on automatic Markdown > HTML translation. All these new parameters have a `null` value by default, so previous calls to these API methods remain compatible. ([#7288](https://github.com/vector-im/element-android/issues/7288))
|
|
||||||
- Add support for `m.login.token` auth during QR code based sign in ([#7358](https://github.com/vector-im/element-android/issues/7358))
|
|
||||||
- Allow getting the formatted or plain text body of a message for the fun `TimelineEvent.getTextEditableContent()`. ([#7359](https://github.com/vector-im/element-android/issues/7359))
|
|
||||||
|
|
||||||
Other changes
|
|
||||||
-------------
|
|
||||||
- Refactor TimelineFragment, split it into MessageComposerFragment and VoiceRecorderFragment. ([#7285](https://github.com/vector-im/element-android/issues/7285))
|
|
||||||
- Dependency to arrow has been removed. Please use `org.matrix.android.sdk.api.util.Optional` instead. ([#7335](https://github.com/vector-im/element-android/issues/7335))
|
|
||||||
- Update WYSIWYG editor designs. ([#7354](https://github.com/vector-im/element-android/issues/7354))
|
|
||||||
- Update WYSIWYG library to v0.2.1. ([#7384](https://github.com/vector-im/element-android/issues/7384))
|
|
||||||
|
|
||||||
|
|
||||||
Changes in Element v1.5.2 (2022-10-05)
|
Changes in Element v1.5.2 (2022-10-05)
|
||||||
======================================
|
======================================
|
||||||
|
|
||||||
|
@ -13,7 +13,6 @@
|
|||||||
* [Code quality](#code-quality)
|
* [Code quality](#code-quality)
|
||||||
* [Internal tool](#internal-tool)
|
* [Internal tool](#internal-tool)
|
||||||
* [ktlint](#ktlint)
|
* [ktlint](#ktlint)
|
||||||
* [knit](#knit)
|
|
||||||
* [lint](#lint)
|
* [lint](#lint)
|
||||||
* [Unit tests](#unit-tests)
|
* [Unit tests](#unit-tests)
|
||||||
* [Tests](#tests)
|
* [Tests](#tests)
|
||||||
@ -127,23 +126,6 @@ Note that you can run
|
|||||||
|
|
||||||
For ktlint to fix some detected errors for you (you still have to check and commit the fix of course)
|
For ktlint to fix some detected errors for you (you still have to check and commit the fix of course)
|
||||||
|
|
||||||
#### knit
|
|
||||||
|
|
||||||
[knit](https://github.com/Kotlin/kotlinx-knit) is a tool which checks markdown files on the project. Also it generates/updates the table of content (toc) of the markdown files.
|
|
||||||
|
|
||||||
So everytime the toc should be updated, just run
|
|
||||||
<pre>
|
|
||||||
./gradlew knit
|
|
||||||
</pre>
|
|
||||||
|
|
||||||
and commit the changes.
|
|
||||||
|
|
||||||
The CI will check that markdown files are up to date by running
|
|
||||||
|
|
||||||
<pre>
|
|
||||||
./gradlew knitCheck
|
|
||||||
</pre>
|
|
||||||
|
|
||||||
#### lint
|
#### lint
|
||||||
|
|
||||||
<pre>
|
<pre>
|
||||||
|
59
README.md
59
README.md
@ -1,58 +1,5 @@
|
|||||||
[![Latest build](https://github.com/vector-im/element-android/actions/workflows/build.yml/badge.svg?query=branch%3Adevelop)](https://github.com/vector-im/element-android/actions/workflows/build.yml?query=branch%3Adevelop)
|
# tester
|
||||||
[![Weblate](https://translate.element.io/widgets/element-android/-/svg-badge.svg)](https://translate.element.io/engage/element-android/?utm_source=widget)
|
|
||||||
[![Element Android Matrix room #element-android:matrix.org](https://img.shields.io/matrix/element-android:matrix.org.svg?label=%23element-android:matrix.org&logo=matrix&server_fqdn=matrix.org)](https://matrix.to/#/#element-android:matrix.org)
|
|
||||||
[![Quality Gate Status](https://sonarcloud.io/api/project_badges/measure?project=vector-im_element-android&metric=alert_status)](https://sonarcloud.io/summary/new_code?id=vector-im_element-android)
|
|
||||||
[![Vulnerabilities](https://sonarcloud.io/api/project_badges/measure?project=vector-im_element-android&metric=vulnerabilities)](https://sonarcloud.io/summary/new_code?id=vector-im_element-android)
|
|
||||||
[![Bugs](https://sonarcloud.io/api/project_badges/measure?project=vector-im_element-android&metric=bugs)](https://sonarcloud.io/summary/new_code?id=vector-im_element-android)
|
|
||||||
|
|
||||||
# Element Android
|
Quick test branch.
|
||||||
|
|
||||||
Element Android is an Android Matrix Client provided by [Element](https://element.io/). The app can be run on every Android devices with Android OS Lollipop and more (API 21).
|
|
||||||
|
|
||||||
It is a total rewrite of [Riot-Android](https://github.com/vector-im/riot-android) with a new user experience.
|
|
||||||
|
|
||||||
[<img src="resources/img/google-play-badge.png" alt="Get it on Google Play" height="60">](https://play.google.com/store/apps/details?id=im.vector.app)
|
|
||||||
[<img src="resources/img/f-droid-badge.png" alt="Get it on F-Droid" height="60">](https://f-droid.org/app/im.vector.app)
|
|
||||||
|
|
||||||
Build of develop branch: [![GitHub Action](https://github.com/vector-im/element-android/actions/workflows/build.yml/badge.svg?query=branch%3Adevelop)](https://github.com/vector-im/element-android/actions/workflows/build.yml?query=branch%3Adevelop) Nightly test status: [![allScreensTest](https://github.com/vector-im/element-android/actions/workflows/nightly.yml/badge.svg)](https://github.com/vector-im/element-android/actions/workflows/nightly.yml)
|
|
||||||
|
|
||||||
|
|
||||||
# New Android SDK
|
|
||||||
|
|
||||||
Element is based on a new Android SDK fully written in Kotlin (like Element). In order to make the early development as fast as possible, Element and the new SDK currently share the same git repository.
|
|
||||||
|
|
||||||
At each Element release, the SDK module is copied to a dedicated repository: https://github.com/matrix-org/matrix-android-sdk2. That way, third party apps can add a regular gradle dependency to use it. So more details on how to do that here: https://github.com/matrix-org/matrix-android-sdk2.
|
|
||||||
|
|
||||||
# Roadmap
|
|
||||||
|
|
||||||
The version 1.0.0 of Element still misses some features which was previously included in Riot-Android.
|
|
||||||
The team will work to add them on a regular basis.
|
|
||||||
|
|
||||||
# Releases to app stores
|
|
||||||
|
|
||||||
There is some delay between when a release is created and when it appears in the app stores (Google Play Store and F-Droid). Here are some of the reasons:
|
|
||||||
|
|
||||||
* Not all versioned releases that appear on GitHub are considered stable. Each release is first considered beta: this continues for at least two days. If the release is stable (no serious issues or crashes are reported), then it is released as a production release in Google Play Store, and a request is sent to F-Droid too.
|
|
||||||
* Each release on the Google Play Store undergoes review by Google before it comes out. This can take an unpredictable amount of time. In some cases it has taken several weeks.
|
|
||||||
* In order for F-Droid to guarantee that the app you receive exactly matches the public source code, they build releases themselves. When a release is considered stable, Element staff inform the F-Droid maintainers and it is added to the build queue. Depending on the load on F-Droid's infrastructure, it can take some time for releases to be built. This always takes at least 24 hours, and can take several days.
|
|
||||||
|
|
||||||
If you would like to receive releases more quickly (bearing in mind that they may not be stable) you have a number of options:
|
|
||||||
|
|
||||||
1. [Sign up to receive beta releases](https://play.google.com/apps/testing/im.vector.app) via the Google Play Store.
|
|
||||||
2. Install a [release APK](https://github.com/vector-im/element-android/releases) directly - download the relevant .apk file and allow installing from untrusted sources in your device settings. Note: these releases are the Google Play version, which depend on some Google services. If you prefer to avoid that, try the latest dev builds, and choose the F-Droid version.
|
|
||||||
3. If you're really brave, install the [very latest dev build](https://github.com/vector-im/element-android/actions/workflows/build.yml?query=branch%3Adevelop) - pick a build, then click on `Summary` to download the APKs from there: `vector-Fdroid-debug` and `vector-Gplay-debug` contains the APK for the desired store. Each file contains 5 APKs. 4 APKs for every supported specific architecture of device. In doubt you can install the `universal` APK.
|
|
||||||
|
|
||||||
## Contributing
|
|
||||||
|
|
||||||
Please refer to [CONTRIBUTING.md](./CONTRIBUTING.md) if you want to contribute on Matrix Android projects!
|
|
||||||
|
|
||||||
Come chat with the community in the dedicated Matrix [room](https://matrix.to/#/#element-android:matrix.org).
|
|
||||||
|
|
||||||
Also [this documentation](./docs/_developer_onboarding.md) can hopefully help developers to start working on the project.
|
|
||||||
|
|
||||||
## Triaging issues
|
|
||||||
|
|
||||||
Issues are triaged by community members and the Android App Team, following the [triage process](https://github.com/vector-im/element-meta/wiki/Triage-process).
|
|
||||||
|
|
||||||
We use [issue labels](https://github.com/vector-im/element-meta/wiki/Issue-labelling) to sort all incoming issues.
|
|
||||||
|
|
||||||
|
Probably shouldn't commit too many times.
|
||||||
|
20
build.gradle
20
build.gradle
@ -24,16 +24,16 @@ buildscript {
|
|||||||
classpath libs.gradle.gradlePlugin
|
classpath libs.gradle.gradlePlugin
|
||||||
classpath libs.gradle.kotlinPlugin
|
classpath libs.gradle.kotlinPlugin
|
||||||
classpath libs.gradle.hiltPlugin
|
classpath libs.gradle.hiltPlugin
|
||||||
classpath 'com.google.firebase:firebase-appdistribution-gradle:3.1.1'
|
classpath 'com.google.firebase:firebase-appdistribution-gradle:3.0.3'
|
||||||
classpath 'com.google.gms:google-services:4.3.14'
|
classpath 'com.google.gms:google-services:4.3.14'
|
||||||
classpath 'org.sonarsource.scanner.gradle:sonarqube-gradle-plugin:3.5.0.2730'
|
classpath 'org.sonarsource.scanner.gradle:sonarqube-gradle-plugin:3.4.0.2513'
|
||||||
classpath 'com.google.android.gms:oss-licenses-plugin:0.10.5'
|
classpath 'com.google.android.gms:oss-licenses-plugin:0.10.5'
|
||||||
classpath "com.likethesalad.android:stem-plugin:2.2.3"
|
classpath "com.likethesalad.android:stem-plugin:2.2.3"
|
||||||
classpath 'org.owasp:dependency-check-gradle:7.4.1'
|
classpath 'org.owasp:dependency-check-gradle:7.2.1'
|
||||||
classpath "org.jetbrains.dokka:dokka-gradle-plugin:1.7.20"
|
classpath "org.jetbrains.dokka:dokka-gradle-plugin:1.7.20"
|
||||||
classpath "org.jetbrains.kotlinx:kotlinx-knit:0.4.0"
|
classpath "org.jetbrains.kotlinx:kotlinx-knit:0.4.0"
|
||||||
classpath 'com.jakewharton:butterknife-gradle-plugin:10.2.3'
|
classpath 'com.jakewharton:butterknife-gradle-plugin:10.2.3'
|
||||||
classpath libs.squareup.paparazziPlugin
|
classpath 'app.cash.paparazzi:paparazzi-gradle-plugin:1.1.0'
|
||||||
// NOTE: Do not place your application dependencies here; they belong
|
// NOTE: Do not place your application dependencies here; they belong
|
||||||
// in the individual module build.gradle files
|
// in the individual module build.gradle files
|
||||||
}
|
}
|
||||||
@ -43,12 +43,12 @@ plugins {
|
|||||||
// ktlint Plugin
|
// ktlint Plugin
|
||||||
id "org.jlleitschuh.gradle.ktlint" version "11.0.0"
|
id "org.jlleitschuh.gradle.ktlint" version "11.0.0"
|
||||||
// Detekt
|
// Detekt
|
||||||
id "io.gitlab.arturbosch.detekt" version "1.22.0"
|
id "io.gitlab.arturbosch.detekt" version "1.21.0"
|
||||||
// Ksp
|
// Ksp
|
||||||
id "com.google.devtools.ksp" version "1.7.22-1.0.8"
|
id "com.google.devtools.ksp" version "1.7.20-1.0.6"
|
||||||
|
|
||||||
// Dependency Analysis
|
// Dependency Analysis
|
||||||
id 'com.autonomousapps.dependency-analysis' version "1.17.0"
|
id 'com.autonomousapps.dependency-analysis' version "1.13.1"
|
||||||
// Gradle doctor
|
// Gradle doctor
|
||||||
id "com.osacky.doctor" version "0.8.1"
|
id "com.osacky.doctor" version "0.8.1"
|
||||||
}
|
}
|
||||||
@ -96,9 +96,9 @@ allprojects {
|
|||||||
}
|
}
|
||||||
// Jitsi repo
|
// Jitsi repo
|
||||||
maven {
|
maven {
|
||||||
url "https://github.com/vector-im/jitsi_libre_maven/raw/main/android-sdk-6.2.2"
|
url "https://github.com/vector-im/jitsi_libre_maven/raw/main/android-sdk-5.0.2"
|
||||||
// Note: to test Jitsi release you can use a local file like this:
|
// Note: to test Jitsi release you can use a local file like this:
|
||||||
// url "file:///Users/bmarty/workspaces/jitsi_libre_maven/android-sdk-6.2.2"
|
// url "file:///Users/bmarty/workspaces/jitsi_libre_maven/android-sdk-3.10.0"
|
||||||
content {
|
content {
|
||||||
groups.jitsi.regex.each { includeGroupByRegex it }
|
groups.jitsi.regex.each { includeGroupByRegex it }
|
||||||
groups.jitsi.group.each { includeGroup it }
|
groups.jitsi.group.each { includeGroup it }
|
||||||
@ -322,7 +322,7 @@ ext.initScreenshotTests = { project ->
|
|||||||
if (hasScreenshots) {
|
if (hasScreenshots) {
|
||||||
project.apply plugin: 'app.cash.paparazzi'
|
project.apply plugin: 'app.cash.paparazzi'
|
||||||
}
|
}
|
||||||
project.dependencies { testCompileOnly libs.squareup.paparazzi }
|
project.dependencies { testCompileOnly "app.cash.paparazzi:paparazzi:1.0.0" }
|
||||||
project.android.testOptions.unitTests.all {
|
project.android.testOptions.unitTests.all {
|
||||||
def screenshotTestCapture = "**/*ScreenshotTest*"
|
def screenshotTestCapture = "**/*ScreenshotTest*"
|
||||||
if (hasScreenshots) {
|
if (hasScreenshots) {
|
||||||
|
@ -1 +0,0 @@
|
|||||||
ReplyTo are not updated if the original message is edited or deleted.
|
|
1
changelog.d/5968.bugfix
Normal file
1
changelog.d/5968.bugfix
Normal file
@ -0,0 +1 @@
|
|||||||
|
Fix wrong mic button direction to cancel on RTL languages
|
1
changelog.d/7217.wip
Normal file
1
changelog.d/7217.wip
Normal file
@ -0,0 +1 @@
|
|||||||
|
Implements MSC3881: Parses `enabled` and `device_id` fields from updated Pusher API
|
1
changelog.d/7257.wip
Normal file
1
changelog.d/7257.wip
Normal file
@ -0,0 +1 @@
|
|||||||
|
[Device Management] Save "matrix_client_information" events on login/registration
|
1
changelog.d/7261.wip
Normal file
1
changelog.d/7261.wip
Normal file
@ -0,0 +1 @@
|
|||||||
|
Adds pusher toggle setting to device manager v2
|
1
changelog.d/7273.wip
Normal file
1
changelog.d/7273.wip
Normal file
@ -0,0 +1 @@
|
|||||||
|
[Voice Broadcast] Add the "io.element.voice_broadcast_info" state event with a minimalist timeline widget
|
1
changelog.d/7277.wip
Normal file
1
changelog.d/7277.wip
Normal file
@ -0,0 +1 @@
|
|||||||
|
[Device Management] Show correct device type icons
|
1
changelog.d/7281.wip
Normal file
1
changelog.d/7281.wip
Normal file
@ -0,0 +1 @@
|
|||||||
|
Links "Enable Notifications for this session" setting to enabled value in pusher
|
1
changelog.d/7282.sdk
Normal file
1
changelog.d/7282.sdk
Normal file
@ -0,0 +1 @@
|
|||||||
|
Stop using `original_event` field from `/relations` endpoint
|
1
changelog.d/7283.wip
Normal file
1
changelog.d/7283.wip
Normal file
@ -0,0 +1 @@
|
|||||||
|
[Voice Broadcast] Aggregate state events in the timeline
|
1
changelog.d/7285.misc
Normal file
1
changelog.d/7285.misc
Normal file
@ -0,0 +1 @@
|
|||||||
|
Refactor TimelineFragment, split it into MessageComposerFragment and VoiceRecorderFragment.
|
1
changelog.d/7288.feature
Normal file
1
changelog.d/7288.feature
Normal file
@ -0,0 +1 @@
|
|||||||
|
Add WYSIWYG editor.
|
10
changelog.d/7288.sdk
Normal file
10
changelog.d/7288.sdk
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
Add `formattedText` or similar optional parameters in several methods:
|
||||||
|
|
||||||
|
* RelationService:
|
||||||
|
* editTextMessage
|
||||||
|
* editReply
|
||||||
|
* replyToMessage
|
||||||
|
* SendService:
|
||||||
|
* sendQuotedTextMessage
|
||||||
|
|
||||||
|
This allows us to send any HTML formatted text message without needing to rely on automatic Markdown > HTML translation. All these new parameters have a `null` value by default, so previous calls to these API methods remain compatible.
|
1
changelog.d/7294.wip
Normal file
1
changelog.d/7294.wip
Normal file
@ -0,0 +1 @@
|
|||||||
|
[Device Management] Render extended device info
|
1
changelog.d/7300.wip
Normal file
1
changelog.d/7300.wip
Normal file
@ -0,0 +1 @@
|
|||||||
|
Implements client-side of local notification settings event
|
1
changelog.d/7310.bugfix
Normal file
1
changelog.d/7310.bugfix
Normal file
@ -0,0 +1 @@
|
|||||||
|
[Device Management] Long session names not handled well
|
1
changelog.d/7321.wip
Normal file
1
changelog.d/7321.wip
Normal file
@ -0,0 +1 @@
|
|||||||
|
[Device management] Improve the parsing for OS of Desktop/Web sessions
|
1
changelog.d/7324.wip
Normal file
1
changelog.d/7324.wip
Normal file
@ -0,0 +1 @@
|
|||||||
|
[Device management] Hide the IP address and last activity date on current session
|
1
changelog.d/7327.wip
Normal file
1
changelog.d/7327.wip
Normal file
@ -0,0 +1 @@
|
|||||||
|
[Device management] Update the unknown verification status icon
|
1
changelog.d/7335.misc
Normal file
1
changelog.d/7335.misc
Normal file
@ -0,0 +1 @@
|
|||||||
|
Dependency to arrow has been removed. Please use `org.matrix.android.sdk.api.util.Optional` instead.
|
1
changelog.d/7336.feature
Normal file
1
changelog.d/7336.feature
Normal file
@ -0,0 +1 @@
|
|||||||
|
[Device management] Add lab flag for the feature
|
1
changelog.d/7338.wip
Normal file
1
changelog.d/7338.wip
Normal file
@ -0,0 +1 @@
|
|||||||
|
Implement QR Code Login UI
|
1
changelog.d/7344.feature
Normal file
1
changelog.d/7344.feature
Normal file
@ -0,0 +1 @@
|
|||||||
|
[Device management] Add lab flag for matrix client info account data event
|
1
changelog.d/7354.misc
Normal file
1
changelog.d/7354.misc
Normal file
@ -0,0 +1 @@
|
|||||||
|
Update WYSIWYG editor designs.
|
1
changelog.d/7358.sdk
Normal file
1
changelog.d/7358.sdk
Normal file
@ -0,0 +1 @@
|
|||||||
|
Add support for `m.login.token` auth during QR code based sign in
|
1
changelog.d/7359.bugfix
Normal file
1
changelog.d/7359.bugfix
Normal file
@ -0,0 +1 @@
|
|||||||
|
Fix editing formatted messages with plain text editor
|
1
changelog.d/7359.sdk
Normal file
1
changelog.d/7359.sdk
Normal file
@ -0,0 +1 @@
|
|||||||
|
Allow getting the formatted or plain text body of a message for the fun `TimelineEvent.getTextEditableContent()`.
|
1
changelog.d/7363.wip
Normal file
1
changelog.d/7363.wip
Normal file
@ -0,0 +1 @@
|
|||||||
|
[Voice Broadcast] Record and send non aggregated voice messages to the room
|
1
changelog.d/7372.bugfix
Normal file
1
changelog.d/7372.bugfix
Normal file
@ -0,0 +1 @@
|
|||||||
|
Handle properly when getUser returns null - prefer using getUserOrDefault
|
1
changelog.d/7374.feature
Normal file
1
changelog.d/7374.feature
Normal file
@ -0,0 +1 @@
|
|||||||
|
[Device Management] Redirect to the new screen everywhere when lab flag is on
|
1
changelog.d/7384.misc
Normal file
1
changelog.d/7384.misc
Normal file
@ -0,0 +1 @@
|
|||||||
|
Update WYSIWYG library to v0.2.1.
|
1
changelog.d/7387.wip
Normal file
1
changelog.d/7387.wip
Normal file
@ -0,0 +1 @@
|
|||||||
|
[Voice Broadcast] Start listening to a voice broadcast
|
1
changelog.d/7393.wip
Normal file
1
changelog.d/7393.wip
Normal file
@ -0,0 +1 @@
|
|||||||
|
[Voice Broadcast] Enable the feature (behind a lab flag and only for Android 10 and up)
|
1
changelog.d/7397.wip
Normal file
1
changelog.d/7397.wip
Normal file
@ -0,0 +1 @@
|
|||||||
|
[Voice Broadcast] Add additional data in events
|
@ -1 +0,0 @@
|
|||||||
[Session manager] Missing info when a session does not support encryption
|
|
@ -1 +0,0 @@
|
|||||||
"[Rich text editor] Add list formatting buttons to the rich text editor"
|
|
@ -1,4 +1,5 @@
|
|||||||
ext.versions = [
|
ext.versions = [
|
||||||
|
|
||||||
'minSdk' : 21,
|
'minSdk' : 21,
|
||||||
'compileSdk' : 33,
|
'compileSdk' : 33,
|
||||||
'targetSdk' : 33,
|
'targetSdk' : 33,
|
||||||
@ -8,17 +9,16 @@ ext.versions = [
|
|||||||
|
|
||||||
def gradle = "7.3.1"
|
def gradle = "7.3.1"
|
||||||
// Ref: https://kotlinlang.org/releases.html
|
// Ref: https://kotlinlang.org/releases.html
|
||||||
def kotlin = "1.7.22"
|
def kotlin = "1.7.20"
|
||||||
def kotlinCoroutines = "1.6.4"
|
def kotlinCoroutines = "1.6.4"
|
||||||
def dagger = "2.44.2"
|
def dagger = "2.44"
|
||||||
def firebaseBom = "31.1.1"
|
def appDistribution = "16.0.0-beta04"
|
||||||
def appDistribution = "16.0.0-beta05"
|
|
||||||
def retrofit = "2.9.0"
|
def retrofit = "2.9.0"
|
||||||
def markwon = "4.6.2"
|
def markwon = "4.6.2"
|
||||||
def moshi = "1.14.0"
|
def moshi = "1.14.0"
|
||||||
def lifecycle = "2.5.1"
|
def lifecycle = "2.5.1"
|
||||||
def flowBinding = "1.2.0"
|
def flowBinding = "1.2.0"
|
||||||
def flipper = "0.176.0"
|
def flipper = "0.171.1"
|
||||||
def epoxy = "5.0.0"
|
def epoxy = "5.0.0"
|
||||||
def mavericks = "3.0.1"
|
def mavericks = "3.0.1"
|
||||||
def glide = "4.14.2"
|
def glide = "4.14.2"
|
||||||
@ -27,20 +27,22 @@ def jjwt = "0.11.5"
|
|||||||
// Temporary version to unblock #6929. Once 0.16.0 is released we should use it, and revert
|
// Temporary version to unblock #6929. Once 0.16.0 is released we should use it, and revert
|
||||||
// the whole commit which set version 0.16.0-SNAPSHOT
|
// the whole commit which set version 0.16.0-SNAPSHOT
|
||||||
def vanniktechEmoji = "0.16.0-SNAPSHOT"
|
def vanniktechEmoji = "0.16.0-SNAPSHOT"
|
||||||
def sentry = "6.9.2"
|
|
||||||
def fragment = "1.5.5"
|
def sentry = "6.4.3"
|
||||||
|
|
||||||
|
def fragment = "1.5.3"
|
||||||
|
|
||||||
// Testing
|
// Testing
|
||||||
def mockk = "1.12.3" // We need to use 1.12.3 to have mocking in androidTest until a new version is released: https://github.com/mockk/mockk/issues/819
|
def mockk = "1.12.3" // We need to use 1.12.3 to have mocking in androidTest until a new version is released: https://github.com/mockk/mockk/issues/819
|
||||||
def espresso = "3.4.0"
|
def espresso = "3.4.0"
|
||||||
def androidxTest = "1.4.0"
|
def androidxTest = "1.4.0"
|
||||||
def androidxOrchestrator = "1.4.2"
|
def androidxOrchestrator = "1.4.1"
|
||||||
def paparazzi = "1.1.0"
|
|
||||||
|
|
||||||
ext.libs = [
|
ext.libs = [
|
||||||
gradle : [
|
gradle : [
|
||||||
'gradlePlugin' : "com.android.tools.build:gradle:$gradle",
|
'gradlePlugin' : "com.android.tools.build:gradle:$gradle",
|
||||||
'kotlinPlugin' : "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin",
|
'kotlinPlugin' : "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin",
|
||||||
'hiltPlugin' : "com.google.dagger:hilt-android-gradle-plugin:$dagger"
|
'hiltPlugin' : "com.google.dagger:hilt-android-gradle-plugin:$dagger"
|
||||||
|
|
||||||
],
|
],
|
||||||
jetbrains : [
|
jetbrains : [
|
||||||
'coroutinesCore' : "org.jetbrains.kotlinx:kotlinx-coroutines-core:$kotlinCoroutines",
|
'coroutinesCore' : "org.jetbrains.kotlinx:kotlinx-coroutines-core:$kotlinCoroutines",
|
||||||
@ -48,12 +50,12 @@ ext.libs = [
|
|||||||
'coroutinesTest' : "org.jetbrains.kotlinx:kotlinx-coroutines-test:$kotlinCoroutines"
|
'coroutinesTest' : "org.jetbrains.kotlinx:kotlinx-coroutines-test:$kotlinCoroutines"
|
||||||
],
|
],
|
||||||
androidx : [
|
androidx : [
|
||||||
'activity' : "androidx.activity:activity-ktx:1.6.1",
|
'activity' : "androidx.activity:activity-ktx:1.6.0",
|
||||||
'appCompat' : "androidx.appcompat:appcompat:1.5.1",
|
'appCompat' : "androidx.appcompat:appcompat:1.5.1",
|
||||||
'biometric' : "androidx.biometric:biometric:1.1.0",
|
'biometric' : "androidx.biometric:biometric:1.1.0",
|
||||||
'core' : "androidx.core:core-ktx:1.9.0",
|
'core' : "androidx.core:core-ktx:1.9.0",
|
||||||
'recyclerview' : "androidx.recyclerview:recyclerview:1.2.1",
|
'recyclerview' : "androidx.recyclerview:recyclerview:1.2.1",
|
||||||
'exifinterface' : "androidx.exifinterface:exifinterface:1.3.5",
|
'exifinterface' : "androidx.exifinterface:exifinterface:1.3.4",
|
||||||
'fragmentKtx' : "androidx.fragment:fragment-ktx:$fragment",
|
'fragmentKtx' : "androidx.fragment:fragment-ktx:$fragment",
|
||||||
'fragmentTesting' : "androidx.fragment:fragment-testing:$fragment",
|
'fragmentTesting' : "androidx.fragment:fragment-testing:$fragment",
|
||||||
'constraintLayout' : "androidx.constraintlayout:constraintlayout:2.1.4",
|
'constraintLayout' : "androidx.constraintlayout:constraintlayout:2.1.4",
|
||||||
@ -80,13 +82,11 @@ ext.libs = [
|
|||||||
'transition' : "androidx.transition:transition:1.2.0",
|
'transition' : "androidx.transition:transition:1.2.0",
|
||||||
],
|
],
|
||||||
google : [
|
google : [
|
||||||
'material' : "com.google.android.material:material:1.7.0",
|
'material' : "com.google.android.material:material:1.6.1",
|
||||||
'firebaseBom' : "com.google.firebase:firebase-bom:$firebaseBom",
|
|
||||||
'messaging' : "com.google.firebase:firebase-messaging",
|
|
||||||
'appdistributionApi' : "com.google.firebase:firebase-appdistribution-api-ktx:$appDistribution",
|
'appdistributionApi' : "com.google.firebase:firebase-appdistribution-api-ktx:$appDistribution",
|
||||||
'appdistribution' : "com.google.firebase:firebase-appdistribution:$appDistribution",
|
'appdistribution' : "com.google.firebase:firebase-appdistribution:$appDistribution",
|
||||||
// Phone number https://github.com/google/libphonenumber
|
// Phone number https://github.com/google/libphonenumber
|
||||||
'phonenumber' : "com.googlecode.libphonenumber:libphonenumber:8.13.3"
|
'phonenumber' : "com.googlecode.libphonenumber:libphonenumber:8.12.57"
|
||||||
],
|
],
|
||||||
dagger : [
|
dagger : [
|
||||||
'dagger' : "com.google.dagger:dagger:$dagger",
|
'dagger' : "com.google.dagger:dagger:$dagger",
|
||||||
@ -101,15 +101,13 @@ ext.libs = [
|
|||||||
],
|
],
|
||||||
element : [
|
element : [
|
||||||
'opusencoder' : "io.element.android:opusencoder:1.1.0",
|
'opusencoder' : "io.element.android:opusencoder:1.1.0",
|
||||||
'wysiwyg' : "io.element.android:wysiwyg:0.13.0"
|
'wysiwyg' : "io.element.android:wysiwyg:0.2.1"
|
||||||
],
|
],
|
||||||
squareup : [
|
squareup : [
|
||||||
'moshi' : "com.squareup.moshi:moshi:$moshi",
|
'moshi' : "com.squareup.moshi:moshi:$moshi",
|
||||||
'moshiKt' : "com.squareup.moshi:moshi-kotlin:$moshi",
|
'moshiKt' : "com.squareup.moshi:moshi-kotlin:$moshi",
|
||||||
'moshiKotlin' : "com.squareup.moshi:moshi-kotlin-codegen:$moshi",
|
'moshiKotlin' : "com.squareup.moshi:moshi-kotlin-codegen:$moshi",
|
||||||
'moshiAdapters' : "com.squareup.moshi:moshi-adapters:$moshi",
|
'moshiAdapters' : "com.squareup.moshi:moshi-adapters:$moshi",
|
||||||
'paparazzi' : "app.cash.paparazzi:paparazzi:$paparazzi",
|
|
||||||
'paparazziPlugin' : "app.cash.paparazzi:paparazzi-gradle-plugin:$paparazzi",
|
|
||||||
'retrofit' : "com.squareup.retrofit2:retrofit:$retrofit",
|
'retrofit' : "com.squareup.retrofit2:retrofit:$retrofit",
|
||||||
'retrofitMoshi' : "com.squareup.retrofit2:converter-moshi:$retrofit"
|
'retrofitMoshi' : "com.squareup.retrofit2:converter-moshi:$retrofit"
|
||||||
],
|
],
|
||||||
@ -132,7 +130,7 @@ ext.libs = [
|
|||||||
'mavericksTesting' : "com.airbnb.android:mavericks-testing:$mavericks"
|
'mavericksTesting' : "com.airbnb.android:mavericks-testing:$mavericks"
|
||||||
],
|
],
|
||||||
maplibre : [
|
maplibre : [
|
||||||
'androidSdk' : "org.maplibre.gl:android-sdk:9.6.0",
|
'androidSdk' : "org.maplibre.gl:android-sdk:9.5.2",
|
||||||
'pluginAnnotation' : "org.maplibre.gl:android-plugin-annotation-v9:1.0.0"
|
'pluginAnnotation' : "org.maplibre.gl:android-plugin-annotation-v9:1.0.0"
|
||||||
],
|
],
|
||||||
mockk : [
|
mockk : [
|
||||||
@ -163,13 +161,13 @@ ext.libs = [
|
|||||||
'emojiGoogle' : "com.vanniktech:emoji-google:$vanniktechEmoji"
|
'emojiGoogle' : "com.vanniktech:emoji-google:$vanniktechEmoji"
|
||||||
],
|
],
|
||||||
apache : [
|
apache : [
|
||||||
'commonsImaging' : "org.apache.commons:commons-imaging:1.0-alpha3"
|
'commonsImaging' : "org.apache.sanselan:sanselan:0.97-incubator"
|
||||||
],
|
],
|
||||||
sentry: [
|
sentry: [
|
||||||
'sentryAndroid' : "io.sentry:sentry-android:$sentry"
|
'sentryAndroid' : "io.sentry:sentry-android:$sentry"
|
||||||
],
|
],
|
||||||
tests : [
|
tests : [
|
||||||
'kluent' : "org.amshove.kluent:kluent-android:1.72",
|
'kluent' : "org.amshove.kluent:kluent-android:1.68",
|
||||||
'timberJunitRule' : "net.lachlanmckee:timber-junit-rule:1.0.1",
|
'timberJunitRule' : "net.lachlanmckee:timber-junit-rule:1.0.1",
|
||||||
'junit' : "junit:junit:4.13.2",
|
'junit' : "junit:junit:4.13.2",
|
||||||
]
|
]
|
||||||
|
@ -176,6 +176,7 @@ ext.groups = [
|
|||||||
'org.apache.ant',
|
'org.apache.ant',
|
||||||
'org.apache.commons',
|
'org.apache.commons',
|
||||||
'org.apache.httpcomponents',
|
'org.apache.httpcomponents',
|
||||||
|
'org.apache.sanselan',
|
||||||
'org.bouncycastle',
|
'org.bouncycastle',
|
||||||
'org.ccil.cowan.tagsoup',
|
'org.ccil.cowan.tagsoup',
|
||||||
'org.checkerframework',
|
'org.checkerframework',
|
||||||
|
@ -1,55 +0,0 @@
|
|||||||
<!--- TOC -->
|
|
||||||
|
|
||||||
* [Testing database migration](#testing-database-migration)
|
|
||||||
* [Creating a reference database](#creating-a-reference-database)
|
|
||||||
* [Testing](#testing)
|
|
||||||
|
|
||||||
<!--- END -->
|
|
||||||
|
|
||||||
## Testing database migration
|
|
||||||
|
|
||||||
### Creating a reference database
|
|
||||||
|
|
||||||
Databases are encrypted, the key to decrypt is needed to setup the test.
|
|
||||||
A special build property must be enabled to extract it.
|
|
||||||
|
|
||||||
Set `vector.debugPrivateData=true` in `~/.gradle/gradle.properties` (to avoid committing by mistake)
|
|
||||||
|
|
||||||
Launch the app in your emulator, login and use the app to fill up the database.
|
|
||||||
|
|
||||||
Save the key for the tested database
|
|
||||||
```
|
|
||||||
RealmKeysUtils W Database key for alias `session_db_fe9f212a611ccf6dea1141777065ed0a`: 935a6dfa0b0fc5cce1414194ed190....
|
|
||||||
RealmKeysUtils W Database key for alias `crypto_module_fe9f212a611ccf6dea1141777065ed0a`: 7b9a21a8a311e85d75b069a343.....
|
|
||||||
```
|
|
||||||
|
|
||||||
|
|
||||||
Use the [Device File Explorer](https://developer.android.com/studio/debug/device-file-explorer) to extrat the database file from the emulator.
|
|
||||||
|
|
||||||
Go to `data/data/im.vector.app.debug/files/<hash>/`
|
|
||||||
Pick the database you want to test (name can be found in SessionRealmConfigurationFactory):
|
|
||||||
- crypto_store.realm for crypto
|
|
||||||
- disk_store.realm for session
|
|
||||||
- etc...
|
|
||||||
|
|
||||||
Download the file on your disk
|
|
||||||
|
|
||||||
### Testing
|
|
||||||
|
|
||||||
Copy the file in `src/AndroidTest/assets`
|
|
||||||
|
|
||||||
see `CryptoSanityMigrationTest` or `RealmSessionStoreMigration43Test` for sample tests.
|
|
||||||
|
|
||||||
There are already some databases in the assets folder.
|
|
||||||
The existing test will properly detect schema changes, and fail with such errors if a migration is missing:
|
|
||||||
|
|
||||||
```
|
|
||||||
io.realm.exceptions.RealmMigrationNeededException: Migration is required due to the following errors:
|
|
||||||
- Property 'CryptoMetadataEntity.foo' has been added.
|
|
||||||
```
|
|
||||||
|
|
||||||
If you want to test properly more complex database migration (dynamic transforms) ensure that the database contains
|
|
||||||
the entity you want to migrate.
|
|
||||||
|
|
||||||
You can explore the database with [realm studio](https://www.mongodb.com/docs/realm/studio/) if needed.
|
|
||||||
|
|
@ -1,52 +0,0 @@
|
|||||||
## Installing from CI
|
|
||||||
|
|
||||||
<!--- TOC -->
|
|
||||||
|
|
||||||
* [Installing from Buildkite](#installing-from-buildkite)
|
|
||||||
* [Installing from GitHub](#installing-from-github)
|
|
||||||
* [Create a GitHub token](#create-a-github-token)
|
|
||||||
* [Provide artifact URL](#provide-artifact-url)
|
|
||||||
* [Next steps](#next-steps)
|
|
||||||
* [Future improvement](#future-improvement)
|
|
||||||
|
|
||||||
<!--- END -->
|
|
||||||
|
|
||||||
Installing APK build by the CI is possible
|
|
||||||
|
|
||||||
### Installing from Buildkite
|
|
||||||
|
|
||||||
The script `./tools/install/installFromBuildkite.sh` can be used, but Builkite will be removed soon. See next section.
|
|
||||||
|
|
||||||
### Installing from GitHub
|
|
||||||
|
|
||||||
To install an APK built by a GitHub action, run the script `./tools/install/installFromGitHub.sh`. You will need to pass a GitHub token to do so.
|
|
||||||
|
|
||||||
#### Create a GitHub token
|
|
||||||
|
|
||||||
You can create a GitHub token going to your Github account, at this page: [https://github.com/settings/tokens](https://github.com/settings/tokens).
|
|
||||||
|
|
||||||
You need to create a token (classic) with the scope `repo/public_repo`. So just check the corresponding checkbox.
|
|
||||||
Validity can be long since the scope of this token is limited. You will still be able to delete the token and generate a new one.
|
|
||||||
Click on Generate token and save the token locally.
|
|
||||||
|
|
||||||
### Provide artifact URL
|
|
||||||
|
|
||||||
The script will ask for an artifact URL. You can get this artifact URL by following these steps:
|
|
||||||
|
|
||||||
- open the pull request
|
|
||||||
- in the check at the bottom, click on `APK Build / Build debug APKs`
|
|
||||||
- click on `Summary`
|
|
||||||
- scroll to the bottom of the page
|
|
||||||
- copy the link `vector-Fdroid-debug` if you want the F-Droid variant or `vector-Gplay-debug` if you want the Gplay variant.
|
|
||||||
|
|
||||||
The copied link can be provided to the script.
|
|
||||||
|
|
||||||
### Next steps
|
|
||||||
|
|
||||||
The script will download the artifact, unzip it and install the correct version (regarding arch) on your device.
|
|
||||||
|
|
||||||
Files will be added to the folder `./tmp/DebugApks`. Feel free to cleanup this folder from time to time, the script will not delete files.
|
|
||||||
|
|
||||||
### Future improvement
|
|
||||||
|
|
||||||
The script could ask the user for a Pull Request number and Gplay/Fdroid choice like it was done with Buildkite script. Using GitHub API may be possible to do that.
|
|
@ -93,4 +93,4 @@ url "https://github.com/vector-im/jitsi_libre_maven/raw/master/android-sdk-3.10.
|
|||||||
|
|
||||||
- Build the project and perform the sanity tests again.
|
- Build the project and perform the sanity tests again.
|
||||||
|
|
||||||
- Create a PR for project Element Android and add a changelog file `<PR_NUMBER>.misc` to notify about the library upgrade.
|
- Update the file `/CHANGES.md` to notify about the library upgrade, and create a regular PR for project Element Android.
|
||||||
|
23
eval_cpu.sh
Executable file
23
eval_cpu.sh
Executable file
@ -0,0 +1,23 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
#set -x
|
||||||
|
#INITIAL_CPU="`cat /proc/stat | grep 'cpu '`"
|
||||||
|
RESULT_CPU="`cat /proc/stat | grep 'cpu '`"
|
||||||
|
|
||||||
|
show() {
|
||||||
|
NAME=$1
|
||||||
|
OFFSET=$2
|
||||||
|
BEFORE=`echo $INITIAL_CPU | cut -d\ -f $OFFSET`
|
||||||
|
AFTER=`echo $RESULT_CPU | cut -d\ -f $OFFSET`
|
||||||
|
echo "$NAME $BEFORE $AFTER ( $(($AFTER - $BEFORE)) )"
|
||||||
|
}
|
||||||
|
|
||||||
|
show "user ", 1
|
||||||
|
show "nice ", 2
|
||||||
|
show "system ", 3
|
||||||
|
show "idle ", 4
|
||||||
|
show "iowait ", 5
|
||||||
|
show "irq ", 6
|
||||||
|
show "softirq", 7
|
||||||
|
show "steal ", 8
|
||||||
|
show "guest ", 9
|
||||||
|
show "guest_nice", 10
|
@ -1 +0,0 @@
|
|||||||
Qrup mesajlaşma - şifrəli mesajlaşma, qrup söhbəti və video zənglər
|
|
@ -1 +0,0 @@
|
|||||||
Element - Təhlükəsiz Mesajlaşma
|
|
@ -1,2 +0,0 @@
|
|||||||
Hlavní změny v této verzi: Nové funkce v Experimentálních funkcích: Rozšířený editor zpráv, nová správa zařízení, hlasové vysílání. Stále v aktivním vývoji!
|
|
||||||
Úplný seznam změn: https://github.com/vector-im/element-android/releases
|
|
@ -1,2 +0,0 @@
|
|||||||
Hlavní změny v této verzi: nové uživatelské rozhraní pro výběr přílohy.
|
|
||||||
Úplný seznam změn: https://github.com/vector-im/element-android/releases
|
|
@ -1,2 +0,0 @@
|
|||||||
Hlavní změny v této verzi: nové uživatelské rozhraní pro výběr přílohy.
|
|
||||||
Úplný seznam změn: https://github.com/vector-im/element-android/releases
|
|
@ -1,2 +0,0 @@
|
|||||||
Hlavní změny v této verzi: opravy různých chyb a vylepšení.
|
|
||||||
Úplný seznam změn: https://github.com/vector-im/element-android/releases
|
|
@ -1,2 +0,0 @@
|
|||||||
Hlavní změny v této verzi: Nová implementace celoobrazovkového režimu pro editor formátovaného textu a opravy chyb.
|
|
||||||
Úplný seznam změn: https://github.com/vector-im/element-android/releases
|
|
@ -1,2 +0,0 @@
|
|||||||
Hlavní změny v této verzi: Nová implementace celoobrazovkového režimu pro editor formátovaného textu a opravy chyb.
|
|
||||||
Úplný seznam změn: https://github.com/vector-im/element-android/releases
|
|
@ -1,2 +0,0 @@
|
|||||||
Hlavní změny v této verzi: Vlákna jsou nyní ve výchozím nastavení povolena.
|
|
||||||
Úplný seznam změn: https://github.com/vector-im/element-android/releases
|
|
@ -1,2 +0,0 @@
|
|||||||
Hlavní změny v této verzi: Vlákna jsou nyní povolena ve výchozím nastavení.
|
|
||||||
Úplný seznam změn: https://github.com/vector-im/element-android/releases
|
|
@ -1,2 +0,0 @@
|
|||||||
Hlavní změny v této verzi: Vlákna jsou nyní povolena ve výchozím nastavení.
|
|
||||||
Úplný seznam změn: https://github.com/vector-im/element-android/releases
|
|
@ -1,2 +1,2 @@
|
|||||||
Die wichtigste Änderung in dieser Version: Verzögerte Direktnachrichten standardmäßig aktiviert!
|
Die wichtigste Änderung in dieser Version: Verzögerte Direktnachrichten standardmäßig aktiviert!
|
||||||
Vollständiges Änderungsprotokoll: https://github.com/vector-im/element-android/releases
|
Vollständiges Änderungsprotokoll: https://github.com/vector-im/element-android/releases/tag/v1.2.0
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
Die wichtigste Änderung in dieser Version: Neues App-Layout standardmäßig aktiviert!
|
Die wichtigste Änderung in dieser Version: Neues App-Layout standardmäßig aktiviert!
|
||||||
Vollständiges Änderungsprotokoll: https://github.com/vector-im/element-android/releases
|
Vollständiges Änderungsprotokoll: https://github.com/vector-im/element-android/releases/tag/v1.2.0
|
||||||
|
@ -1,2 +0,0 @@
|
|||||||
Die wichtigste Änderung in dieser Version: Neue Funktionen in den Labor-Einstellungen: Textverarbeitungs-Editor, neue Geräteverwaltung, Sprachübertragung. Noch in aktiver Entwicklung!
|
|
||||||
Vollständiges Änderungsprotokoll: https://github.com/vector-im/element-android/releases
|
|
@ -1,2 +0,0 @@
|
|||||||
Die wichtigste Änderung in dieser Version: Neues Anhangauswahl-UI.
|
|
||||||
Vollständiges Änderungsprotokoll: https://github.com/vector-im/element-android/releases
|
|
@ -1,2 +0,0 @@
|
|||||||
Die wichtigste Änderung in dieser Version: Neue Anhangauswahl-Oberfläche.
|
|
||||||
Vollständiges Änderungsprotokoll: https://github.com/vector-im/element-android/releases
|
|
@ -1,2 +0,0 @@
|
|||||||
Die wichtigsten Änderungen in dieser Version: Fehlerbehebungen und Verbesserungen.
|
|
||||||
Vollständiges Änderungsprotokoll: https://github.com/vector-im/element-android/releases
|
|
@ -1,2 +0,0 @@
|
|||||||
Die wichtigsten Änderungen in dieser Version: Der Vollbildmodus des Textverarbeitungseditors wurde neu umgesetzt und es wurden diverse Fehler behoben.
|
|
||||||
Vollständiges Änderungsprotokoll: https://github.com/vector-im/element-android/releases
|
|
@ -1,2 +0,0 @@
|
|||||||
Die wichtigsten Änderungen in dieser Version: Der Vollbildmodus des Textverarbeitungseditors wurde neu umgesetzt und es wurden diverse Fehler behoben.
|
|
||||||
Vollständiges Änderungsprotokoll: https://github.com/vector-im/element-android/releases
|
|
@ -1,2 +0,0 @@
|
|||||||
Die wichtigsten Änderungen in dieser Version: Threads sind nun automatisch aktiviert.
|
|
||||||
Vollständiges Änderungsprotokoll: https://github.com/vector-im/element-android/releases
|
|
@ -1,2 +0,0 @@
|
|||||||
Die wichtigsten Änderungen in dieser Version: Threads sind nun automatisch aktiviert.
|
|
||||||
Vollständiges Änderungsprotokoll: https://github.com/vector-im/element-android/releases
|
|
@ -1,2 +0,0 @@
|
|||||||
Die wichtigsten Änderungen in dieser Version: Threads sind nun standardmäßig aktiviert.
|
|
||||||
Vollständiges Änderungsprotokoll: https://github.com/vector-im/element-android/releases
|
|
@ -1,2 +0,0 @@
|
|||||||
Main changes in this version: New features under the labs settings: Rich text composer, new device management, voice broadcast. Still under active development!
|
|
||||||
Full changelog: https://github.com/vector-im/element-android/releases
|
|
@ -1,2 +0,0 @@
|
|||||||
Main changes in this version: new UI for selecting an attachment.
|
|
||||||
Full changelog: https://github.com/vector-im/element-android/releases
|
|
@ -1,2 +0,0 @@
|
|||||||
Main changes in this version: new UI for selecting an attachment.
|
|
||||||
Full changelog: https://github.com/vector-im/element-android/releases
|
|
@ -1,2 +0,0 @@
|
|||||||
Main changes in this version: bug fixes and improvements.
|
|
||||||
Full changelog: https://github.com/vector-im/element-android/releases
|
|
@ -1,2 +0,0 @@
|
|||||||
Main changes in this version: New implementation of the full screen mode for the Rich Text Editor and bugfixes.
|
|
||||||
Full changelog: https://github.com/vector-im/element-android/releases
|
|
@ -1,2 +0,0 @@
|
|||||||
Main changes in this version: New implementation of the full screen mode for the Rich Text Editor and bugfixes.
|
|
||||||
Full changelog: https://github.com/vector-im/element-android/releases
|
|
@ -1,2 +0,0 @@
|
|||||||
Main changes in this version: Thread are now enabled by default.
|
|
||||||
Full changelog: https://github.com/vector-im/element-android/releases
|
|
@ -1,2 +0,0 @@
|
|||||||
Main changes in this version: Thread are now enabled by default.
|
|
||||||
Full changelog: https://github.com/vector-im/element-android/releases
|
|
@ -1,2 +0,0 @@
|
|||||||
Main changes in this version: Thread are now enabled by default.
|
|
||||||
Full changelog: https://github.com/vector-im/element-android/releases
|
|
@ -1,2 +0,0 @@
|
|||||||
Main changes in this version: Thread are now enabled by default.
|
|
||||||
Full changelog: https://github.com/vector-im/element-android/releases
|
|
@ -1,2 +0,0 @@
|
|||||||
Main changes in this version: Thread are now enabled by default.
|
|
||||||
Full changelog: https://github.com/vector-im/element-android/releases
|
|
@ -1,2 +0,0 @@
|
|||||||
Põhilised muutused selles versioonis: Uued võimalused katsete all: vormindatud teksti põhine toimeti, uus seadmehaldus, ringhäälingukõned (kõik on hetkel aktiivsel arendamisel).
|
|
||||||
Kogu ingliskeelne muudatuste logi: https://github.com/vector-im/element-android/releases
|
|
@ -1,2 +0,0 @@
|
|||||||
Põhilised muutused selles versioonis: uus liides manuste lisamiseks.
|
|
||||||
Kogu ingliskeelne muudatuste logi: https://github.com/vector-im/element-android/releases
|
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user