From ae2ba2fe72c930999251d04aaef57cbef808f89b Mon Sep 17 00:00:00 2001 From: Chris Kipp Date: Sat, 9 Jul 2022 13:29:24 +0200 Subject: [PATCH] deps: update all sorts of stuff (#17) This pr goes through and makes the various updates: - Bumps mill to the latest 0.10.5 - Bumps to the latest Scala versions for 2 and latest 3.1.x version - Drops 0.x support for ScalaJS - Move Scala native to 0.4.x - Adds in dependabot - Starts to cross test on 8 and 17 - Updates checkout and java actions --- .github/dependabot.yml | 7 ++++++ .github/workflows/actions.yml | 21 ++++++++++------ .mill-version | 1 + build.sc | 47 ++++++++++++++++++----------------- mill | 2 +- 5 files changed, 47 insertions(+), 31 deletions(-) create mode 100644 .github/dependabot.yml create mode 100644 .mill-version diff --git a/.github/dependabot.yml b/.github/dependabot.yml new file mode 100644 index 0000000..e33811f --- /dev/null +++ b/.github/dependabot.yml @@ -0,0 +1,7 @@ +version: 2 +updates: + + - package-ecosystem: "github-actions" + directory: "/" + schedule: + interval: "monthly" diff --git a/.github/workflows/actions.yml b/.github/workflows/actions.yml index 4d21c8f..56e5519 100644 --- a/.github/workflows/actions.yml +++ b/.github/workflows/actions.yml @@ -9,21 +9,27 @@ on: jobs: test: runs-on: ubuntu-latest + strategy: + matrix: + java: ['8', '17'] steps: - - uses: actions/checkout@v2 - - uses: actions/setup-java@v1 + - uses: actions/checkout@v3 + - uses: actions/setup-java@v3 with: - java-version: 8 + distribution: 'temurin' + java-version: ${{ matrix.java }} - name: Run tests run: ./mill -i all __.publishArtifacts __.test + check-binary-compatibility: runs-on: ubuntu-latest steps: - - uses: actions/checkout@v2 + - uses: actions/checkout@v3 with: fetch-depth: 0 - - uses: actions/setup-java@v1 + - uses: actions/setup-java@v3 with: + distribution: 'temurin' java-version: 8 - name: Check Binary Compatibility run: ./mill -i __.mimaReportBinaryIssues @@ -41,9 +47,10 @@ jobs: LC_MESSAGES: "en_US.UTF-8" LC_ALL: "en_US.UTF-8" steps: - - uses: actions/checkout@v2 - - uses: actions/setup-java@v1 + - uses: actions/checkout@v3 + - uses: actions/setup-java@v3 with: + distribution: 'temurin' java-version: 8 - name: Publish to Maven Central run: | diff --git a/.mill-version b/.mill-version new file mode 100644 index 0000000..9028ec6 --- /dev/null +++ b/.mill-version @@ -0,0 +1 @@ +0.10.5 diff --git a/build.sc b/build.sc index 5b41341..b95d889 100644 --- a/build.sc +++ b/build.sc @@ -1,41 +1,42 @@ import mill._, scalalib._, scalajslib._, scalanativelib._, publish._ import $ivy.`de.tototec::de.tobiasroeser.mill.vcs.version::0.1.4` import de.tobiasroeser.mill.vcs.version.VcsVersion -import $ivy.`com.github.lolgab::mill-mima::0.0.9` +import $ivy.`com.github.lolgab::mill-mima::0.0.10` import com.github.lolgab.mill.mima._ +import mill.scalalib.api.Util.isScala3 -val dottyVersions = sys.props.get("dottyVersion").toList +val communityBuildDottyVersion = sys.props.get("dottyVersion").toList val scala211 = "2.11.12" -val scala212 = "2.12.13" -val scala213 = "2.13.4" -val scala30 = "3.0.0" -val scala31 = "3.1.1" +val scala212 = "2.12.16" +val scala213 = "2.13.8" +val scala3 = "3.1.3" -val scala2VersionsAndDotty = scala213 :: scala212 :: scala211 :: dottyVersions +val scalaVersions = scala3 :: scala213 :: scala212 :: scala211 :: communityBuildDottyVersion -val scalaJSVersions = for { - scalaV <- scala30 :: scala2VersionsAndDotty - scalaJSV <- Seq("0.6.33", "1.5.1") - if scalaV.startsWith("2.") || scalaJSV.startsWith("1.") -} yield (scalaV, scalaJSV) +val scalaJSVersions = scalaVersions.map((_, "1.10.1")) +val scalaNativeVersions = scalaVersions.map((_, "0.4.5")) -val scalaNativeVersions = for { - scalaV <- scala31 :: scala2VersionsAndDotty - scalaNativeV <- Seq("0.4.3") -} yield (scalaV, scalaNativeV) +trait MimaCheck extends Mima { + def mimaPreviousVersions = VcsVersion.vcsState().lastTag.toSeq +} object castor extends Module { - abstract class ActorModule(crossVersion: String) extends CrossScalaModule with PublishModule with Mima { + abstract class ActorModule(crossVersion: String) extends CrossScalaModule with PublishModule with MimaCheck { def publishVersion = VcsVersion.vcsState().format() - def mimaPreviousVersions = VcsVersion.vcsState().lastTag.toSeq + + // Temporary until the next version of Mima gets released with + // https://github.com/lightbend/mima/issues/693 included in the release. + def mimaPreviousArtifacts = + if(isScala3(crossVersion)) Agg.empty[Dep] else super.mimaPreviousArtifacts() + def crossScalaVersion = crossVersion def pomSettings = PomSettings( description = artifactName(), organization = "com.lihaoyi", - url = "https://github.com/lihaoyi/castor", + url = "https://github.com/com-lihaoyi/castor", licenses = Seq(License.MIT), - versionControl = VersionControl.github("lihaoyi", "castor"), + versionControl = VersionControl.github("com-lihaoyi", "castor"), developers = Seq( Developer("lihaoyi", "Li Haoyi","https://github.com/lihaoyi") ) @@ -58,7 +59,7 @@ object castor extends Module { millSourcePath / "src", millSourcePath / s"src-$platformSegment" ) - def ivyDeps = Agg(ivy"com.lihaoyi::utest::0.7.11") + def ivyDeps = Agg(ivy"com.lihaoyi::utest::0.8.0") } object js extends Cross[ActorJsModule](scalaJSVersions:_*) @@ -74,13 +75,13 @@ object castor extends Module { def scalaVersion = crossScalaVersion } } - object jvm extends Cross[ActorJvmModule](scala30 :: scala2VersionsAndDotty: _*) + object jvm extends Cross[ActorJvmModule](scalaVersions: _*) class ActorJvmModule(crossScalaVersion: String) extends ActorModule(crossScalaVersion) { def platformSegment = "jvm" object test extends Tests with ActorTestModule{ def platformSegment: String = "jvm" def ivyDeps = super.ivyDeps() ++ Agg( - ivy"com.lihaoyi::os-lib:0.7.7" + ivy"com.lihaoyi::os-lib:0.8.1" ) } } diff --git a/mill b/mill index 4d3405d..e616548 100755 --- a/mill +++ b/mill @@ -3,7 +3,7 @@ # This is a wrapper script, that automatically download mill from GitHub release pages # You can give the required mill version with MILL_VERSION env variable # If no version is given, it falls back to the value of DEFAULT_MILL_VERSION -DEFAULT_MILL_VERSION=0.10.0-35-11bc3c +DEFAULT_MILL_VERSION=0.10.5 set -e