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

Update dependencies #328

Merged
merged 5 commits into from
Jan 26, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,9 @@ import com.android.tools.lint.checks.infrastructure.TestFile
import com.android.tools.lint.checks.infrastructure.TestFiles.kotlin
import com.android.tools.lint.checks.infrastructure.TestLintResult
import com.android.tools.lint.checks.infrastructure.TestLintTask.lint
import com.android.tools.lint.checks.infrastructure.TestMode
import com.instacart.formula.lint.WrongFormulaUsageDetector.Companion.issues
import com.intellij.lang.PsiBuilderUtil.expect
import org.junit.Test

class WrongFormulaUsageDetectorTest {
Expand Down Expand Up @@ -95,6 +97,7 @@ class WrongFormulaUsageDetectorTest {
return lint()
.files(*array)
.issues(*issues)
.skipTestModes(TestMode.SUPPRESSIBLE)
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This seems to be needed with the latest lint version, otherwise these tests will fail.

.run()
}

Expand Down
16 changes: 8 additions & 8 deletions gradle/libs.versions.toml
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
[versions]
android-gradle = "8.2.0"
android-gradle = "8.2.2"
dokka-gradle = "1.9.10"

kotlin = "1.9.10"
Expand All @@ -10,20 +10,20 @@ compose-compiler = "1.5.3"

androidX = "1.2.0"
lifecycle = "2.2.0"
lifecycleKtx = '2.4.0-alpha03'
lifecycleKtx = '2.6.2'
androidTest = "1.4.0"
espresso = "3.4.0"
robolectric = "4.11.1"
lint = "30.0.0"
autoService = "1.0-rc7"
lint = "31.2.2"
autoService = "1.1.1"

[libraries]
android-gradle = { module = "com.android.tools.build:gradle", version.ref = "android-gradle" }
kotlin-gradle = { module = "org.jetbrains.kotlin:kotlin-gradle-plugin", version.ref = "kotlin" }
dokka-gradle = { module = "org.jetbrains.dokka:dokka-gradle-plugin", version.ref = "dokka-gradle" }
dokka-android-gradle = { module = "org.jetbrains.dokka:android-documentation-plugin", version.ref = "dokka-gradle" }
maven-publish-gradle = { module = "com.vanniktech:gradle-maven-publish-plugin", version = "0.14.2" }
version-gradle = { module = "com.github.ben-manes:gradle-versions-plugin", version = "0.38.0" }
version-gradle = { module = "com.github.ben-manes:gradle-versions-plugin", version = "0.36.0" }
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Downgrade?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Oops 🙈


# We need to fork the plugin to fix an incorrect usage of tasks.withType(Test)
# https://github.com/vanniktech/gradle-android-junit-jacoco-plugin/compare/master...Laimiux:gradle-android-junit-jacoco-plugin:laimonas/gradle-8?expand=1
Expand Down Expand Up @@ -58,15 +58,15 @@ lifecycle-runtime-ktx = { module = "androidx.lifecycle:lifecycle-runtime-ktx", v
espresso-core = { module = "androidx.test.espresso:espresso-core", version.ref = "espresso" }
robolectric = { module = "org.robolectric:robolectric", version.ref = "robolectric" }

rxjava = { module = "io.reactivex.rxjava3:rxjava", version = "3.1.1" }
rxjava = { module = "io.reactivex.rxjava3:rxjava", version = "3.1.6" }
rxandroid = { module = "io.reactivex.rxjava3:rxandroid", version = "3.0.0" }
rxrelay = { module = "com.jakewharton.rxrelay3:rxrelay", version = "3.0.1" }

truth = { module = "com.google.truth:truth", version = "1.1.3" }
truth = { module = "com.google.truth:truth", version = "1.1.5" }
junit = { module = "junit:junit", version = "4.13.2" }
rxrelays = { module = "com.jakewharton.rxrelay3:rxrelay", version = "3.0.1" }

mockito-core = { module = "org.mockito:mockito-core", version = "5.7.0" }
mockito-core = { module = "org.mockito:mockito-core", version = "5.8.0" }
mockito-kotlin = { module = "org.mockito.kotlin:mockito-kotlin", version = "5.2.1" }

lint-core = { module = "com.android.tools.lint:lint", version.ref = "lint" }
Expand Down
2 changes: 1 addition & 1 deletion gradle/wrapper/gradle-wrapper.properties
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
#Wed Dec 13 14:59:32 PST 2023
distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
distributionUrl=https\://services.gradle.org/distributions/gradle-8.2-bin.zip
distributionUrl=https\://services.gradle.org/distributions/gradle-8.5-bin.zip
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists
2 changes: 1 addition & 1 deletion jacoco.sh
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
#!/bin/bash
# Should match with what we run in .circleci/config.yml
# Should match with what we run in .github/workflows/build-workflow.yml
./gradlew clean
./gradlew :formula:test
./gradlew :formula-android:testRelease
Expand Down
3 changes: 2 additions & 1 deletion jitpack.yml
Original file line number Diff line number Diff line change
@@ -1 +1,2 @@
jdk: openjdk11
jdk:
- openjdk18
2 changes: 0 additions & 2 deletions samples/todoapp/build.gradle.kts
Original file line number Diff line number Diff line change
Expand Up @@ -43,8 +43,6 @@ dependencies {

testImplementation(libs.junit)
testImplementation(libs.truth)
testImplementation(libs.mockito.core)
testImplementation(libs.mockito.kotlin)
testImplementation(libs.kotlin.reflect)
testImplementation(project(":formula-test"))
testImplementation(libs.androidx.test.runner)
Expand Down
Original file line number Diff line number Diff line change
@@ -1,14 +1,16 @@
package com.examples.todoapp

import com.examples.todoapp.data.TaskRepo
import com.examples.todoapp.data.TaskRepoImpl
import com.examples.todoapp.tasks.TaskListFeatureFactory
import com.examples.todoapp.tasks.TaskListFormula
import com.instacart.formula.android.ActivityStoreContext

class TodoAppComponent(
private val store: ActivityStoreContext<TodoActivity>
) : TaskListFeatureFactory.Dependencies {
private val repo: TaskRepo = TaskRepo()

private val repo: TaskRepo = TaskRepoImpl()

override fun taskRepo(): TaskRepo {
return repo
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,32 +4,12 @@ import com.examples.todoapp.tasks.TaskCompletedEvent
import com.jakewharton.rxrelay3.BehaviorRelay
import io.reactivex.rxjava3.core.Observable
import io.reactivex.rxjava3.android.schedulers.AndroidSchedulers
import io.reactivex.rxjava3.core.Scheduler
import java.util.concurrent.TimeUnit

class TaskRepo {
private val localStore: BehaviorRelay<List<Task>> = BehaviorRelay.createDefault(
listOf(
Task("Mow the lawn."),
Task("Go get a haircut.")
)
)
interface TaskRepo {

fun tasks(): Observable<List<Task>> {
// Fake initial network request
return Observable.timer(5, TimeUnit.SECONDS).observeOn(AndroidSchedulers.mainThread()).flatMap {
localStore
}
}
fun tasks(): Observable<List<Task>>

fun onTaskCompleted(event: TaskCompletedEvent) {
val updated = localStore.value!!.map {
if (it.id == event.taskId) {
it.copy(isCompleted = event.isCompleted)
} else {
it
}
}

localStore.accept(updated)
}
fun onTaskCompleted(event: TaskCompletedEvent)
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
package com.examples.todoapp.data

import com.examples.todoapp.tasks.TaskCompletedEvent
import com.jakewharton.rxrelay3.BehaviorRelay
import io.reactivex.rxjava3.android.schedulers.AndroidSchedulers
import io.reactivex.rxjava3.core.Observable
import java.util.concurrent.TimeUnit

class TaskRepoImpl : TaskRepo {
private val localStore: BehaviorRelay<List<Task>> = BehaviorRelay.createDefault(
listOf(
Task("Mow the lawn."),
Task("Go get a haircut.")
)
)

override fun tasks(): Observable<List<Task>> {
// Fake initial network request
return Observable.timer(5, TimeUnit.SECONDS).observeOn(AndroidSchedulers.mainThread()).flatMap {
localStore
}
}

override fun onTaskCompleted(event: TaskCompletedEvent) {
val updated = localStore.value!!.map {
if (it.id == event.taskId) {
it.copy(isCompleted = event.isCompleted)
} else {
it
}
}

localStore.accept(updated)
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ package com.examples.todoapp.tasks

import com.instacart.formula.Listener

class TaskItemRenderModel(
data class TaskItemRenderModel(
val id: String,
val text: String,
val isSelected: Boolean,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,24 +4,21 @@ import com.examples.todoapp.data.Task
import com.examples.todoapp.data.TaskRepo
import com.google.common.truth.Truth.assertThat
import com.instacart.formula.test.test
import com.nhaarman.mockito_kotlin.mock
import com.nhaarman.mockito_kotlin.whenever
import io.reactivex.rxjava3.core.Observable
import org.junit.Test

class TaskListFormulaTest {

@Test fun `change filter type`() {
val repo = mock<TaskRepo>()
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for removing mocking

whenever(repo.tasks()).thenReturn(Observable.just(
listOf(
Task("Mow the lawn."),
Task("Go get a haircut.")
)
))
private val showToast = { toast: String ->

}

@Test
fun `change filter type`() {
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I wasn't sure if we wanted to keep this test around, it doesn't currently run in CI

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I would like to keep it as an example

val repo = TaskRepoFake()

TaskListFormula(repo)
.test(TaskListFormula.Input(showToast = {}))
.test(TaskListFormula.Input(showToast = showToast))
.output {
assertThat(items).hasSize(2)
}
Expand All @@ -32,4 +29,19 @@ class TaskListFormulaTest {
assertThat(items).isEmpty()
}
}

class TaskRepoFake : TaskRepo {
override fun tasks(): Observable<List<Task>> {
return Observable.just(
listOf(
Task("Mow the lawn."),
Task("Go get a haircut.")
)
)
}

override fun onTaskCompleted(event: TaskCompletedEvent) {
// nothing to do
}
}
}
Loading