Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add integration tests for ksp library modules. #5054

Merged

Conversation

sjudd
Copy link
Collaborator

@sjudd sjudd commented Mar 8, 2023

I've added a new module ksp:integrationtest so that we can keep the pollution from the dependent module out of the normal library glide module tests. There's more detail in the documentation for the build.gradle file in ksp:integrationtests.

This does at least make sure that if a dependent module is added, it is successfully included by ksp. Previously the tests only tested either library modules compiled with the app glide module or library modules compiled by ksp. This new set of tests now tests library modules compiled by java. If we ever compile a module with ksp, we should add that module to these tests as well so that we have integration tests for both types of modules. For now all modules are compiled only with the java processor.

In an ideal world we'd be able to just run the Java annotation processor using kotlin compile testing the same way we are with ksp. The library seems to support it. However I can't figure out a way to get the javax annotations and kotlin and android all available in a single gradle module. For now using a separate module is reasonable (if somewhat clunky) compromise.

I've added a new module ksp:integrationtest so that we can keep the
pollution from the dependent module out of the normal library glide
module tests. There's more detail in the documentation for the
build.gradle file in ksp:integrationtests.

This does at least make sure that if a dependent module is added, it is
succesfully included by ksp. Previously the tests only tested either
library modules compiled with the app glide module or library modules
compiled by ksp. This new set of tests now tests library modules
compiled by java. If we ever compile a module with ksp, we should add
that module to these tests as well so that we have integration tests for
both types of modules. For now all modules are compiled only with the
java processor.

In an ideal world we'd be able to just run the Java annotation processor
using kotlin compile testing the same way we are with ksp. The library
seems to support it. However I can't figure out a way to get the javax
annotations and kotlin and android all available in a single gradle
module. For now using a separate module is reasonable (if somewhat
clunky) compromise.
@sjudd sjudd added the import-ready Indicates the PR is ready to be imported to Google. label Mar 8, 2023
@copybara-service copybara-service bot merged commit 501dedb into bumptech:master Mar 8, 2023
nikclayton added a commit to pachli/pachli-android that referenced this pull request Oct 13, 2023
[![Mend
Renovate](https://app.renovatebot.com/images/banner.svg)](https://renovatebot.com)

This PR contains the following updates:

| Package | Change | Age | Adoption | Passing | Confidence |
|---|---|---|---|---|---|
|
[com.github.bumptech.glide:okhttp3-integration](https://github.com/bumptech/glide)
| `4.15.1` -> `4.16.0` |
[![age](https://developer.mend.io/api/mc/badges/age/maven/com.github.bumptech.glide:okhttp3-integration/4.16.0?slim=true)](https://docs.renovatebot.com/merge-confidence/)
|
[![adoption](https://developer.mend.io/api/mc/badges/adoption/maven/com.github.bumptech.glide:okhttp3-integration/4.16.0?slim=true)](https://docs.renovatebot.com/merge-confidence/)
|
[![passing](https://developer.mend.io/api/mc/badges/compatibility/maven/com.github.bumptech.glide:okhttp3-integration/4.15.1/4.16.0?slim=true)](https://docs.renovatebot.com/merge-confidence/)
|
[![confidence](https://developer.mend.io/api/mc/badges/confidence/maven/com.github.bumptech.glide:okhttp3-integration/4.15.1/4.16.0?slim=true)](https://docs.renovatebot.com/merge-confidence/)
|
| [com.github.bumptech.glide:glide](https://github.com/bumptech/glide)
| `4.15.1` -> `4.16.0` |
[![age](https://developer.mend.io/api/mc/badges/age/maven/com.github.bumptech.glide:glide/4.16.0?slim=true)](https://docs.renovatebot.com/merge-confidence/)
|
[![adoption](https://developer.mend.io/api/mc/badges/adoption/maven/com.github.bumptech.glide:glide/4.16.0?slim=true)](https://docs.renovatebot.com/merge-confidence/)
|
[![passing](https://developer.mend.io/api/mc/badges/compatibility/maven/com.github.bumptech.glide:glide/4.15.1/4.16.0?slim=true)](https://docs.renovatebot.com/merge-confidence/)
|
[![confidence](https://developer.mend.io/api/mc/badges/confidence/maven/com.github.bumptech.glide:glide/4.15.1/4.16.0?slim=true)](https://docs.renovatebot.com/merge-confidence/)
|
| [com.github.bumptech.glide:ksp](https://github.com/bumptech/glide) |
`4.15.1` -> `4.16.0` |
[![age](https://developer.mend.io/api/mc/badges/age/maven/com.github.bumptech.glide:ksp/4.16.0?slim=true)](https://docs.renovatebot.com/merge-confidence/)
|
[![adoption](https://developer.mend.io/api/mc/badges/adoption/maven/com.github.bumptech.glide:ksp/4.16.0?slim=true)](https://docs.renovatebot.com/merge-confidence/)
|
[![passing](https://developer.mend.io/api/mc/badges/compatibility/maven/com.github.bumptech.glide:ksp/4.15.1/4.16.0?slim=true)](https://docs.renovatebot.com/merge-confidence/)
|
[![confidence](https://developer.mend.io/api/mc/badges/confidence/maven/com.github.bumptech.glide:ksp/4.15.1/4.16.0?slim=true)](https://docs.renovatebot.com/merge-confidence/)
|

---

### Release Notes

<details>
<summary>bumptech/glide
(com.github.bumptech.glide:okhttp3-integration)</summary>

###
[`v4.16.0`](https://github.com/bumptech/glide/releases/tag/v4.16.0):
Glide 4.16.0

This release focuses on some build improvements and Compose. The two
major Compose improvements are adding support for Compose specific
transitions (e.g. cross fade) and supporting recomposition based on
request state using `GlideSubcomposition`. There's also been a bunch of
internal refactoring to move away from Painters to Modifier nodes based
on feedback from the Compose team. This is still an alpha release of
Compose, but barring unexpectedly negative feedback, the next release
should be beta.

This should be the last release of Glide that targets Java 7. That
probably means our next release will be a major version change.

##### Features

- Allow passing an executor into ChromiumRequestSerializer in
[bumptech/glide#5077
- Allow host app to provide a way to clear all resources onStop() by
[@&#8203;osamaaftab](https://github.com/osamaaftab) in
[bumptech/glide#5145

##### Compose

- Add a Transition API and a CrossFade Transition for Compose by
[@&#8203;sjudd](https://github.com/sjudd) in
[bumptech/glide#5235

- Influence layout using intrinsics in GlideNode by
[@&#8203;sjudd](https://github.com/sjudd) in
[bumptech/glide#5240
\* Log instead of throwing parsing manifests to fix compose previews by
[@&#8203;sjudd](https://github.com/sjudd) in
[bumptech/glide#5167

- Launch no more than one request per onRemembered by
[@&#8203;sjudd](https://github.com/sjudd) in
[bumptech/glide#5062

- Remove GlidePainter in favor of Modifier nodes / Flows by
[@&#8203;sjudd](https://github.com/sjudd) in
[bumptech/glide#5230

- Replace flows in GlideSubcomposition with a listener on GlideNode by
[@&#8203;sjudd](https://github.com/sjudd) in
[bumptech/glide#5238

##### Bugs

- Read library glide module names from Java indexes by
[@&#8203;sjudd](https://github.com/sjudd) in
[bumptech/glide#5052
- Fix typo. anay -> any in GlideSymbolProcessor.kt. by
[@&#8203;trevorhackman](https://github.com/trevorhackman) in
[bumptech/glide#5029
- Include URL in error log by
[@&#8203;paulsowden](https://github.com/paulsowden) in
[bumptech/glide#5164
- Add `isInitialized` visible for testing method by
[@&#8203;paulsowden](https://github.com/paulsowden) in
[bumptech/glide#5163
- Use onIdle to avoid a race in FlowTests by
[@&#8203;sjudd](https://github.com/sjudd) in
[bumptech/glide#5202
- Add a isEquivalentTo method to correctly check equality by
[@&#8203;mori-atsushi](https://github.com/mori-atsushi) in
[bumptech/glide#5232
- Add
[@&#8203;RequiresPermission](https://github.com/RequiresPermission) to
NotificationTarget by
[@&#8203;TWiStErRob](https://github.com/TWiStErRob) in
[bumptech/glide#5220

##### Deprecations

- `placeholderOf(@&#8203;Composable)` in `GlideImage` is deprecated, use
`GlideSubcomposition` instead. Keep in mind that using either forces a
recomposition each time the state of the image load changes.
Recomposition will have a significant performance penalty in scrolling
lists and should be avoided.

##### Behavior Changes

- Hard code disabling hardware bitmaps on O/OMR1. by
[@&#8203;sjudd](https://github.com/sjudd) in
[bumptech/glide#5115
- Do not set requireOriginal on Android photo picker uris. by
[@&#8203;phoenixli](https://github.com/phoenixli) in
[bumptech/glide#5162

##### Breaking Changes

##### Build Changes

- Add integration tests for ksp library modules. by
[@&#8203;sjudd](https://github.com/sjudd) in
[bumptech/glide#5054
- Update README.md to use https by
[@&#8203;simoarpe](https://github.com/simoarpe) in
[bumptech/glide#5058
- Use dokka to build scripts/update_javadocs.sh by
[@&#8203;sjudd](https://github.com/sjudd) in
[bumptech/glide#5104
- avif integration: Update libavif dependency by
[@&#8203;vigneshvg](https://github.com/vigneshvg) in
[bumptech/glide#5128
- Disable java 7 source obsolete warning. by
[@&#8203;sjudd](https://github.com/sjudd) in
[bumptech/glide#5168
- Update mockito version to fix j16 compilation. by
[@&#8203;sjudd](https://github.com/sjudd) in
[bumptech/glide#5169
- Switch Glide's dependencies to a version catalog. by
[@&#8203;sjudd](https://github.com/sjudd) in
[bumptech/glide#5183
- Remove jetifier by [@&#8203;sjudd](https://github.com/sjudd) in
[bumptech/glide#5184
- Add an updated proguard plugin to compile on Java 17. by
[@&#8203;sjudd](https://github.com/sjudd) in
[bumptech/glide#5185
- Configure Renovate in
[bumptech/glide#5186
- Increment ROBOLECTRIC_SDK to 19 from 18. by
[@&#8203;brettchabot](https://github.com/brettchabot) in
[bumptech/glide#5208
and
[bumptech/glide#5207
- AGP: Upgrade AndroidManifest.xml's package to build.gradle's
namespace. by [@&#8203;TWiStErRob](https://github.com/TWiStErRob) in
[bumptech/glide#5221

##### New Contributors

- [@&#8203;trevorhackman](https://github.com/trevorhackman) made their
first contribution in
[bumptech/glide#5029
- [@&#8203;simoarpe](https://github.com/simoarpe) made their first
contribution in
[bumptech/glide#5058
- [@&#8203;paulsowden](https://github.com/paulsowden) made their first
contribution in
[bumptech/glide#5164
- [@&#8203;phoenixli](https://github.com/phoenixli) made their first
contribution in
[bumptech/glide#5162
- [@&#8203;osamaaftab](https://github.com/osamaaftab) made their first
contribution in
[bumptech/glide#5145
- [@&#8203;brettchabot](https://github.com/brettchabot) made their
first contribution in
[bumptech/glide#5207
- [@&#8203;mori-atsushi](https://github.com/mori-atsushi) made their
first contribution in
[bumptech/glide#5232

**Full Changelog**:
bumptech/glide@v4.15.0...v4.16.0

Note - there's been a change in the gpg key used to sign these releases.
The new public key is attached

</details>

---

### Configuration

📅 **Schedule**: Branch creation - At any time (no schedule defined),
Automerge - At any time (no schedule defined).

🚦 **Automerge**: Disabled by config. Please merge this manually once you
are satisfied.

♻ **Rebasing**: Whenever PR becomes conflicted, or you tick the
rebase/retry checkbox.

🔕 **Ignore**: Close this PR and you won't be reminded about these
updates again.

---

- [ ] <!-- rebase-check -->If you want to rebase/retry this PR, check
this box

---

This PR has been generated by [Mend
Renovate](https://www.mend.io/free-developer-tools/renovate/). View
repository job log
[here](https://developer.mend.io/github/pachli/pachli-android).

<!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiIzNi4xMDcuMiIsInVwZGF0ZWRJblZlciI6IjM3LjguMSIsInRhcmdldEJyYW5jaCI6Im1haW4ifQ==-->

---------

Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
Co-authored-by: Nik Clayton <nik@ngo.org.uk>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
import-ready Indicates the PR is ready to be imported to Google.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

None yet

1 participant