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

Fix issues regarding serialization and error handling #13

Merged
merged 27 commits into from
Jan 16, 2024
Merged
Show file tree
Hide file tree
Changes from 13 commits
Commits
Show all changes
27 commits
Select commit Hold shift + click to select a range
4a164ba
!wip
uniumuniu Oct 18, 2023
a1a9ecb
test commit
uniumuniu Oct 18, 2023
5b78435
Revert "test commit"
uniumuniu Oct 18, 2023
ea136a6
Finish Instance+Feature.kt and Instance+Segments.kt
uniumuniu Oct 18, 2023
2f8de11
Introduce Instance exstension functions
uniumuniu Oct 20, 2023
cc069fd
Update README.md
uniumuniu Oct 20, 2023
90d3f12
Apply codestyle
uniumuniu Oct 25, 2023
4e36ebd
Fix unit tests
uniumuniu Oct 25, 2023
6ddf82c
Add custom serializers
uniumuniu Nov 7, 2023
7cd8733
Fix deserializaing of VariableValue
uniumuniu Nov 9, 2023
be9dbcf
Merge remote-tracking branch 'origin/main' into migrate-instance
uniumuniu Nov 9, 2023
8cd4e71
types to separate package
uniumuniu Nov 9, 2023
974f79d
fix package path
uniumuniu Nov 9, 2023
9cb2cf1
clean-up
uniumuniu Nov 15, 2023
009f515
fix issues with variables
uniumuniu Nov 27, 2023
c671d5f
Remove some logs
uniumuniu Nov 29, 2023
08b5041
Fix operator serializing
uniumuniu Nov 29, 2023
9755161
Fix conditions
uniumuniu Dec 5, 2023
ec27537
Fix conditions deserialization
uniumuniu Dec 6, 2023
82641f1
Fix issues with json variables
uniumuniu Dec 8, 2023
586b962
Fix integer variable serialization
uniumuniu Dec 27, 2023
cb08f53
Fix operator
uniumuniu Dec 28, 2023
e336dfc
Fix serialization issues
uniumuniu Dec 28, 2023
2229f2d
Fix error handling
uniumuniu Dec 28, 2023
c576116
Add unit tests for serializers
uniumuniu Jan 14, 2024
c890002
Revert removing SegmentKey alias
uniumuniu Jan 14, 2024
f653af3
Remove unnecessary comments
uniumuniu Jan 14, 2024
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
3 changes: 2 additions & 1 deletion build.gradle.kts
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,8 @@ import org.gradle.api.tasks.testing.logging.TestLogEvent

plugins {
// Apply the org.jetbrains.kotlin.jvm Plugin to add support for Kotlin.
id("org.jetbrains.kotlin.jvm") version "1.8.20"
kotlin("jvm") version "1.9.20"
kotlin("plugin.serialization") version "1.9.20"

// Apply the java-library plugin for API and implementation separation.
`java-library`
Expand Down
3 changes: 1 addition & 2 deletions src/main/kotlin/com/featurevisor/sdk/DatafileReader.kt
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,6 @@ import com.featurevisor.types.DatafileContent
import com.featurevisor.types.Feature
import com.featurevisor.types.FeatureKey
import com.featurevisor.types.Segment
import com.featurevisor.types.SegmentKey

class DatafileReader constructor(
datafileJson: DatafileContent,
Expand Down Expand Up @@ -34,7 +33,7 @@ class DatafileReader constructor(
return attributes.find { attribute -> attribute.key == attributeKey }
}

fun getSegment(segmentKey: SegmentKey): Segment? {
fun getSegment(segmentKey: String): Segment? {
uniumuniu marked this conversation as resolved.
Show resolved Hide resolved
return segments.find { segment -> segment.key == segmentKey }
}

Expand Down
6 changes: 3 additions & 3 deletions src/main/kotlin/com/featurevisor/sdk/Instance+Evaluation.kt
Original file line number Diff line number Diff line change
Expand Up @@ -612,7 +612,7 @@ private fun FeaturevisorInstance.getBucketKey(feature: Feature, context: Context

is BucketBy.Or -> {
type = "or"
attributeKeys = bucketBy.bucketBy.or
attributeKeys = bucketBy.bucketBy
}
}

Expand All @@ -632,9 +632,9 @@ private fun FeaturevisorInstance.getBucketKey(feature: Feature, context: Context

bucketKey.add(AttributeValue.StringValue(featureKey))

val result = bucketKey.map {
val result = bucketKey.joinToString(separator = bucketKeySeparator) {
it.toString()
}.joinToString(separator = bucketKeySeparator)
}

configureBucketKey?.let { configureBucketKey ->
return configureBucketKey(feature, context, result)
Expand Down
2 changes: 1 addition & 1 deletion src/main/kotlin/com/featurevisor/sdk/Instance+Feature.kt
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ import com.featurevisor.types.Feature
import com.featurevisor.types.Force
import com.featurevisor.types.Traffic

internal fun FeaturevisorInstance.getFeatureByKey(featureKey: String): Feature? {
fun FeaturevisorInstance.getFeatureByKey(featureKey: String): Feature? {
return datafileReader.getFeature(featureKey)
}

Expand Down
29 changes: 22 additions & 7 deletions src/main/kotlin/com/featurevisor/sdk/Instance+Fetch.kt
Original file line number Diff line number Diff line change
Expand Up @@ -39,21 +39,36 @@ private fun fetchDatafileContentFromUrl(
}
}

private inline fun <reified T> fetch(
const val BODY_BYTE_COUNT = 1000000L
private inline fun fetch(
request: Request,
crossinline completion: (Result<T>) -> Unit,
crossinline completion: (Result<DatafileContent>) -> Unit,
) {
val client = OkHttpClient()
val call = client.newCall(request)
call.enqueue(object : Callback {
override fun onResponse(call: Call, response: Response) {
val responseBody = response.body
if (response.isSuccessful && responseBody != null) {
val json = Json { ignoreUnknownKeys = true }
val content = json.decodeFromString<T>(responseBody.string())
val responseBody = response.peekBody(BODY_BYTE_COUNT)
if (response.isSuccessful) {
val json = Json {
ignoreUnknownKeys = true
serializersModule = this.serializersModule.apply {

}
}
val responseBodyString = responseBody.string()
FeaturevisorInstance.companionLogger?.debug(responseBodyString)
val content = json.decodeFromString<DatafileContent>(responseBodyString)
completion(Result.success(content))
} else {
completion(Result.failure(FeaturevisorError.UnparsableJson(responseBody?.string(), response.message)))
completion(
Result.failure(
FeaturevisorError.UnparsableJson(
responseBody.string(),
response.message
)
)
)
}
}

Expand Down
5 changes: 4 additions & 1 deletion src/main/kotlin/com/featurevisor/sdk/Instance.kt
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,8 @@ class FeaturevisorInstance private constructor(options: InstanceOptions) {
fun createInstance(options: InstanceOptions): FeaturevisorInstance {
return FeaturevisorInstance(options)
}

var companionLogger: Logger? = null
}

private val on: (EventName, Listener) -> Unit
Expand Down Expand Up @@ -58,6 +60,7 @@ class FeaturevisorInstance private constructor(options: InstanceOptions) {

init {
with(options) {
companionLogger = logger
if (onReady != null) {
emitter.addListener(event = READY, listener = onReady)
}
Expand Down Expand Up @@ -96,7 +99,7 @@ class FeaturevisorInstance private constructor(options: InstanceOptions) {
if (result.isSuccess) {
datafileReader = DatafileReader(result.getOrThrow())
statuses.ready = true
emitter.emit(READY)
emitter.emit(READY, result.getOrThrow())
if (refreshInterval != null) startRefreshing()
} else {
logger?.error("Failed to fetch datafile: $result")
Expand Down
Loading
Loading