Skip to content

Commit

Permalink
Merge pull request #687 from armanbilge/feature/native
Browse files Browse the repository at this point in the history
Cross-build for Native
  • Loading branch information
ChristopherDavenport authored Sep 15, 2022
2 parents 240a0b4 + 9f9c5f6 commit b435d1a
Show file tree
Hide file tree
Showing 5 changed files with 91 additions and 33 deletions.
42 changes: 39 additions & 3 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -30,14 +30,16 @@ jobs:
os: [ubuntu-latest]
scala: [2.13.8, 2.12.16, 3.1.3]
java: [temurin@8, temurin@11]
project: [rootJS, rootJVM]
project: [rootJS, rootJVM, rootNative]
exclude:
- scala: 2.12.16
java: temurin@11
- scala: 3.1.3
java: temurin@11
- project: rootJS
java: temurin@11
- project: rootNative
java: temurin@11
runs-on: ${{ matrix.os }}
steps:
- name: Checkout current branch (full)
Expand Down Expand Up @@ -100,6 +102,10 @@ jobs:
if: matrix.project == 'rootJS'
run: sbt 'project ${{ matrix.project }}' '++${{ matrix.scala }}' Test/scalaJSLinkerResult

- name: nativeLink
if: matrix.project == 'rootNative'
run: sbt 'project ${{ matrix.project }}' '++${{ matrix.scala }}' Test/nativeLink

- name: Test
run: sbt 'project ${{ matrix.project }}' '++${{ matrix.scala }}' test

Expand All @@ -113,11 +119,11 @@ jobs:

- name: Make target directories
if: github.event_name != 'pull_request' && (startsWith(github.ref, 'refs/tags/v') || github.ref == 'refs/heads/main')
run: mkdir -p testing/jvm/target noop/jvm/target target .js/target site/target core/js/target testing/js/target noop/js/target core/jvm/target .jvm/target .native/target slf4j/target project/target
run: mkdir -p testing/jvm/target noop/jvm/target target .js/target core/native/target site/target testing/native/target noop/native/target core/js/target testing/js/target noop/js/target core/jvm/target .jvm/target .native/target slf4j/target project/target

- name: Compress target directories
if: github.event_name != 'pull_request' && (startsWith(github.ref, 'refs/tags/v') || github.ref == 'refs/heads/main')
run: tar cf targets.tar testing/jvm/target noop/jvm/target target .js/target site/target core/js/target testing/js/target noop/js/target core/jvm/target .jvm/target .native/target slf4j/target project/target
run: tar cf targets.tar testing/jvm/target noop/jvm/target target .js/target core/native/target site/target testing/native/target noop/native/target core/js/target testing/js/target noop/js/target core/jvm/target .jvm/target .native/target slf4j/target project/target

- name: Upload target directories
if: github.event_name != 'pull_request' && (startsWith(github.ref, 'refs/tags/v') || github.ref == 'refs/heads/main')
Expand Down Expand Up @@ -206,6 +212,16 @@ jobs:
tar xf targets.tar
rm targets.tar
- name: Download target directories (2.13.8, rootNative)
uses: actions/download-artifact@v2
with:
name: target-${{ matrix.os }}-${{ matrix.java }}-2.13.8-rootNative

- name: Inflate target directories (2.13.8, rootNative)
run: |
tar xf targets.tar
rm targets.tar
- name: Download target directories (2.12.16, rootJS)
uses: actions/download-artifact@v2
with:
Expand All @@ -226,6 +242,16 @@ jobs:
tar xf targets.tar
rm targets.tar
- name: Download target directories (2.12.16, rootNative)
uses: actions/download-artifact@v2
with:
name: target-${{ matrix.os }}-${{ matrix.java }}-2.12.16-rootNative

- name: Inflate target directories (2.12.16, rootNative)
run: |
tar xf targets.tar
rm targets.tar
- name: Download target directories (3.1.3, rootJS)
uses: actions/download-artifact@v2
with:
Expand All @@ -246,6 +272,16 @@ jobs:
tar xf targets.tar
rm targets.tar
- name: Download target directories (3.1.3, rootNative)
uses: actions/download-artifact@v2
with:
name: target-${{ matrix.os }}-${{ matrix.java }}-3.1.3-rootNative

- name: Inflate target directories (3.1.3, rootNative)
run: |
tar xf targets.tar
rm targets.tar
- name: Import signing key
if: env.PGP_SECRET != '' && env.PGP_PASSPHRASE == ''
run: echo $PGP_SECRET | base64 -di | gpg --import
Expand Down
27 changes: 15 additions & 12 deletions build.sbt
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ val Scala213 = "2.13.8"
val Scala212 = "2.12.16"
val Scala3 = "3.1.3"

ThisBuild / tlBaseVersion := "2.4"
ThisBuild / tlBaseVersion := "2.5"
ThisBuild / crossScalaVersions := Seq(Scala213, Scala212, Scala3)
ThisBuild / scalaVersion := Scala213
ThisBuild / startYear := Some(2018)
Expand All @@ -29,7 +29,7 @@ ThisBuild / tlVersionIntroduced := Map("3" -> "2.1.1")
val catsV = "2.8.0"
val catsEffectV = "3.3.14"
val slf4jV = "1.7.36"
val munitCatsEffectV = "1.0.7"
val munitCatsEffectV = "2.0.0-M3"
val logbackClassicV = "1.2.11"

Global / onChangedBuildSource := ReloadOnSourceChanges
Expand All @@ -41,25 +41,22 @@ lazy val docs = project
.enablePlugins(TypelevelSitePlugin)
.dependsOn(slf4j)

lazy val core = crossProject(JSPlatform, JVMPlatform)
lazy val core = crossProject(JSPlatform, JVMPlatform, NativePlatform)
.settings(commonSettings)
.settings(
name := "log4cats-core",
libraryDependencies ++= Seq(
"org.typelevel" %%% "cats-core" % catsV
"org.typelevel" %%% "cats-core" % catsV,
"org.typelevel" %%% "cats-effect-std" % catsEffectV
),
libraryDependencies ++= {
if (tlIsScala3.value) Seq.empty
else Seq("org.scala-lang" % "scala-reflect" % scalaVersion.value % Provided)
}
)
.jsSettings(
// https://www.scala-js.org/news/2022/04/04/announcing-scalajs-1.10.0#fixes-with-compatibility-concerns
libraryDependencies += ("org.scala-js" %%% "scalajs-java-securerandom" % "1.0.0")
.cross(CrossVersion.for3Use2_13)
)
.nativeSettings(commonNativeSettings)

lazy val testing = crossProject(JSPlatform, JVMPlatform)
lazy val testing = crossProject(JSPlatform, JVMPlatform, NativePlatform)
.settings(commonSettings)
.dependsOn(core)
.settings(
Expand All @@ -69,13 +66,15 @@ lazy val testing = crossProject(JSPlatform, JVMPlatform)
"ch.qos.logback" % "logback-classic" % logbackClassicV % Test
)
)
.nativeSettings(commonNativeSettings)

lazy val noop = crossProject(JSPlatform, JVMPlatform)
lazy val noop = crossProject(JSPlatform, JVMPlatform, NativePlatform)
.settings(commonSettings)
.dependsOn(core)
.settings(
name := "log4cats-noop"
)
.nativeSettings(commonNativeSettings)

lazy val slf4j = project
.settings(commonSettings)
Expand All @@ -95,6 +94,10 @@ lazy val slf4j = project

lazy val commonSettings = Seq(
libraryDependencies ++= Seq(
"org.typelevel" %%% "munit-cats-effect-3" % munitCatsEffectV % Test
"org.typelevel" %%% "munit-cats-effect" % munitCatsEffectV % Test
)
)

lazy val commonNativeSettings = Seq(
tlVersionIntroduced := List("2.12", "2.13", "3").map(_ -> "2.4.1").toMap
)
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,8 @@
package org.typelevel.log4cats

import cats._
import cats.implicits._
import cats.effect.std.UUIDGen
import cats.syntax.all._

import java.io.{PrintWriter, StringWriter}
import java.util.UUID
Expand Down Expand Up @@ -52,19 +53,35 @@ object PagingSelfAwareStructuredLogger {
* @return
* SelfAwareStructuredLogger with pagination.
*/
def paged[F[_]: Monad: UUIDGen](pageSizeK: Int = 64, maxPageNeeded: Int = 999)(
logger: SelfAwareStructuredLogger[F]
): SelfAwareStructuredLogger[F] =
new PagingSelfAwareStructuredLogger[F](pageSizeK, maxPageNeeded, UUIDGen.randomUUID)(logger)

@deprecated("Use paged", "2.5.0")
def withPaging[F[_]: Monad](pageSizeK: Int = 64, maxPageNeeded: Int = 999)(
logger: SelfAwareStructuredLogger[F]
): SelfAwareStructuredLogger[F] =
new PagingSelfAwareStructuredLogger[F](pageSizeK, maxPageNeeded)(logger)

private class PagingSelfAwareStructuredLogger[F[_]: Monad](pageSizeK: Int, maxPageNeeded: Int)(
private class PagingSelfAwareStructuredLogger[F[_]: Monad](
pageSizeK: Int,
maxPageNeeded: Int,
randomUUID: F[UUID]
)(
sl: SelfAwareStructuredLogger[F]
) extends SelfAwareStructuredLogger[F] {
if (pageSizeK <= 0 || maxPageNeeded <= 0)
throw new IllegalArgumentException(
s"pageSizeK(=$pageSizeK) and maxPageNeeded(=$maxPageNeeded) must be positive numbers."
)

@deprecated("Use constructor with randomUUID", "2.5.0")
def this(pageSizeK: Int, maxPageNeeded: Int)(
sl: SelfAwareStructuredLogger[F]
) =
this(pageSizeK, maxPageNeeded, Monad[F].unit.map(_ => UUID.randomUUID()))(sl)

private val pageIndices = (1 to maxPageNeeded).toList
private val logSplitIdN = "log_split_id"
private val pageSize = pageSizeK * 1024
Expand Down Expand Up @@ -100,16 +117,17 @@ object PagingSelfAwareStructuredLogger {
private def addCtx(
msg: => String,
ctx: Map[String, String]
): (String, Map[String, String]) = {
val logSplitId = UUID.randomUUID().show
(
logSplitId,
ctx
.updated(logSplitIdN, logSplitId)
.updated("page_size", s"${pageSizeK.show} Kib")
.updated("log_size", s"${msg.length.show} Byte")
)
}
): F[(String, Map[String, String])] =
randomUUID.map { uuid =>
val logSplitId = uuid.show
(
logSplitId,
ctx
.updated(logSplitIdN, logSplitId)
.updated("page_size", s"${pageSizeK.show} Kib")
.updated("log_size", s"${msg.length.show} Byte")
)
}

private def doLogging(
loggingLevelChk: => F[Boolean],
Expand All @@ -118,8 +136,7 @@ object PagingSelfAwareStructuredLogger {
ctx: Map[String, String] = Map()
): F[Unit] = {
loggingLevelChk.ifM(
{
val (logSplitId, newCtx) = addCtx(msg, ctx)
addCtx(msg, ctx).flatMap { case (logSplitId, newCtx) =>
pagedLogging(logOpWithCtx(newCtx), logSplitId, msg)
},
Applicative[F].unit
Expand Down
6 changes: 4 additions & 2 deletions project/plugins.sbt
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
addSbtPlugin("org.scala-js" % "sbt-scalajs" % "1.10.1")
addSbtPlugin("pl.project13.scala" % "sbt-jmh" % "0.4.3")
addSbtPlugin("org.scala-js" % "sbt-scalajs" % "1.10.1")
addSbtPlugin("org.scala-native" % "sbt-scala-native" % "0.4.7")
addSbtPlugin("org.portable-scala" % "sbt-scala-native-crossproject" % "1.2.0")
addSbtPlugin("pl.project13.scala" % "sbt-jmh" % "0.4.3")
val sbtTypelevelVersion = "0.4.13"
addSbtPlugin("org.typelevel" % "sbt-typelevel" % sbtTypelevelVersion)
addSbtPlugin("org.typelevel" % "sbt-typelevel-site" % sbtTypelevelVersion)
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,7 @@ class PagingSelfAwareStructuredLoggerTestRunner extends CatsEffectSuite {
val pageSize = pageSizeK * 1024
val stl = StructuredTestingLogger.impl[IO]()
val pagingStl: SelfAwareStructuredLogger[IO] =
PagingSelfAwareStructuredLogger.withPaging[IO](pageSizeK, maxPageNeeded)(stl)
PagingSelfAwareStructuredLogger.paged[IO](pageSizeK, maxPageNeeded)(stl)
val logResult: IO[Unit] = logTest(pagingStl)

val test = logResult >> stl.logged
Expand Down Expand Up @@ -103,7 +103,7 @@ class PagingSelfAwareStructuredLoggerTestRunner extends CatsEffectSuite {
): Unit = {
val stl = StructuredTestingLogger.impl[IO]()
try {
PagingSelfAwareStructuredLogger.withPaging[IO](pageSizeK, maxPageNeeded)(stl)
PagingSelfAwareStructuredLogger.paged[IO](pageSizeK, maxPageNeeded)(stl)
fail(s"$suiteName $caseName: Expected exception not thrown")
} catch {
case thr: Throwable => assert(thr.isInstanceOf[IllegalArgumentException])
Expand Down

0 comments on commit b435d1a

Please sign in to comment.