Skip to content

Commit

Permalink
Remove joda time (#153)
Browse files Browse the repository at this point in the history
* rm joda time

* Upd CHANGELOG

Co-authored-by: Grigory Pomadchin <[email protected]>
  • Loading branch information
jisantuc and pomadchin authored Sep 29, 2020
1 parent 8c745a4 commit 2d2b64c
Show file tree
Hide file tree
Showing 8 changed files with 45 additions and 14 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@

- All implicit imports from cats are moved to specific `cats.syntax.foo` imports [#146](https://github.com/azavea/stac4s/pull/146)
- Time types are derived from `org.joda.time.Instant` instead of stock `java` time types [#152](https://github.com/azavea/stac4s/pull/152)
- Remove joda time [#153](https://github.com/azavea/stac4s/pull/153)

### Added

Expand Down
2 changes: 0 additions & 2 deletions build.sbt
Original file line number Diff line number Diff line change
Expand Up @@ -110,7 +110,6 @@ val coreDependencies = Seq(
"io.circe" %% "circe-generic" % Versions.CirceVersion,
"io.circe" %% "circe-parser" % Versions.CirceVersion,
"io.circe" %% "circe-refined" % Versions.CirceVersion,
"joda-time" % "joda-time" % Versions.JodaTime,
"org.locationtech.geotrellis" %% "geotrellis-vector" % Versions.GeoTrellisVersion,
"org.locationtech.jts" % "jts-core" % Versions.Jts,
"org.typelevel" %% "cats-core" % Versions.CatsVersion,
Expand All @@ -124,7 +123,6 @@ val testingDependencies = Seq(
"eu.timepit" %% "refined" % Versions.RefinedVersion,
"io.chrisdavenport" %% "cats-scalacheck" % Versions.ScalacheckCatsVersion,
"io.circe" %% "circe-core" % Versions.CirceVersion,
"joda-time" % "joda-time" % Versions.JodaTime,
"org.locationtech.geotrellis" %% "geotrellis-vector" % Versions.GeoTrellisVersion,
"org.locationtech.jts" % "jts-core" % Versions.Jts,
"org.scalacheck" %% "scalacheck" % Versions.ScalacheckVersion,
Expand Down
17 changes: 15 additions & 2 deletions modules/core-test/src/test/scala/com/azavea/stac4s/SerDeSpec.scala
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,8 @@ import geotrellis.vector.Geometry
import io.circe.syntax._
import io.circe.parser._
import io.circe.testing.{ArbitraryInstances, CodecTests}
import org.joda.time.Instant
import java.time.{Instant, OffsetDateTime}

import org.scalatest.Assertion
import org.scalatest.funsuite.AnyFunSuite
import org.scalatest.matchers.should.Matchers
Expand Down Expand Up @@ -71,7 +72,7 @@ class SerDeSpec extends AnyFunSuite with FunSuiteDiscipline with Checkers with M

// timezone parsing unit tests
private def getTimeDecodeTest(timestring: String): Assertion =
timestring.asJson.as[Instant] shouldBe (Right(Instant.parse(timestring)))
timestring.asJson.as[Instant] shouldBe Right(OffsetDateTime.parse(timestring, RFC3339formatter).toInstant)

test("Instant decodes timestrings with +0x:00 timezones") {
getTimeDecodeTest("2018-01-01T00:00:00+05:00")
Expand All @@ -92,4 +93,16 @@ class SerDeSpec extends AnyFunSuite with FunSuiteDiscipline with Checkers with M
test("Instant decodes timestrings with -00 format timezone") {
getTimeDecodeTest("2018-01-01T00:00:00-00")
}

test("Instant decodes timestring with Z format timezone") {
getTimeDecodeTest("2020-04-03T11:32:26Z")
}

test("Instant decodes timestring with 1e3 Z format timezone") {
getTimeDecodeTest("2018-04-03T11:32:26.553Z")
}

test("Instant decodes timestring with 1e9 Z format timezone") {
getTimeDecodeTest("2018-04-03T11:32:26.553955473Z")
}
}
Original file line number Diff line number Diff line change
@@ -1,15 +1,15 @@
package com.azavea.stac4s.meta

import com.azavea.stac4s.TemporalExtent

import cats.Eq
import cats.syntax.either._
import eu.timepit.refined.api.RefType
import geotrellis.vector.Geometry
import io.circe._
import io.circe.parser.decode
import io.circe.syntax._
import org.joda.time.Instant
import java.time.{Instant, OffsetDateTime}
import java.time.format.{DateTimeFormatter, DateTimeFormatterBuilder}

import scala.util.Try

Expand All @@ -20,11 +20,31 @@ trait ForeignImplicits {
implicit val eqGeometry: Eq[Geometry] = Eq.fromUniversalEquals

// circe codecs
// A more flexible alternative to DateTimeFormatter.ofPattern("yyyy-MM-dd'T'HH:mm:ss.SSS[xxx][xx][X]")
// https://tools.ietf.org/html/rfc3339
// Warning: This formatter is good only for parsing
val RFC3339formatter =
new DateTimeFormatterBuilder()
.append(DateTimeFormatter.ISO_LOCAL_DATE_TIME)
.optionalStart()
.appendOffset("+HH:MM", "+00:00")
.optionalEnd()
.optionalStart()
.appendOffset("+HHMM", "+0000")
.optionalEnd()
.optionalStart()
.appendOffset("+HH", "Z")
.optionalEnd()
.toFormatter()

implicit val encodeJodaInstant: Encoder[Instant] = Encoder[String].contramap(_.toString)
implicit val encodeInstant: Encoder[Instant] = Encoder[String].contramap(_.toString)

implicit val decodeJodaInstant: Decoder[Instant] =
Decoder[String].emap(s => Either.fromTry(Try(Instant.parse(s))).leftMap(_ => s"$s was not a valid string format"))
implicit val decodeInstant: Decoder[Instant] =
Decoder[String].emap(s =>
Either
.fromTry(Try(OffsetDateTime.parse(s, RFC3339formatter).toInstant))
.leftMap(_ => s"$s was not a valid string format")
)

implicit val encodeTemporalExtent: Encoder[TemporalExtent] = _.value.map(x => x.asJson).asJson

Expand Down
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
package com.azavea.stac4s.meta

import eu.timepit.refined.api.Validate
import org.joda.time.Instant
import java.time.Instant

final case class HasInstant()

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ import eu.timepit.refined.api.{Refined, RefinedTypeOps}
import eu.timepit.refined.boolean._
import eu.timepit.refined.collection.{Exists, MinSize, _}

import org.joda.time.Instant
import java.time.Instant

package object stac4s {

Expand Down
4 changes: 2 additions & 2 deletions modules/testing/src/main/scala/testing.scala
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ import io.circe.syntax._
import org.scalacheck._
import org.scalacheck.Arbitrary.arbitrary
import org.scalacheck.cats.implicits._
import org.joda.time.Instant
import java.time.Instant

package object testing extends NumericInstances {

Expand Down Expand Up @@ -51,7 +51,7 @@ package object testing extends NumericInstances {
)
}).widen

private def instantGen: Gen[Instant] = arbitrary[Int] map { x => new Instant(x.toLong) }
private def instantGen: Gen[Instant] = arbitrary[Int] map { x => Instant.now.plusMillis(x.toLong) }

private def assetCollectionExtensionGen: Gen[AssetCollectionExtension] =
possiblyEmptyMapGen(
Expand Down
1 change: 0 additions & 1 deletion project/Versions.scala
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,6 @@ object Versions {
val CatsVersion = "2.2.0"
val CirceVersion = "0.13.0"
val GeoTrellisVersion = "3.5.0"
val JodaTime = "2.10.6"
val Jts = "1.16.1"
val RefinedVersion = "0.9.17"
val ScalacheckCatsVersion = "0.3.0"
Expand Down

0 comments on commit 2d2b64c

Please sign in to comment.