Skip to content

Commit

Permalink
Merge pull request chronotope#446 from schrieveslaach/feature/js-sys-…
Browse files Browse the repository at this point in the history
…date-improvements

Improve From<js_sys::Date> Variants for DateTime<Utc>
  • Loading branch information
quodlibetor authored Jul 5, 2020
2 parents 4348cd1 + 073d86a commit 6be7be3
Show file tree
Hide file tree
Showing 6 changed files with 40 additions and 25 deletions.
5 changes: 5 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,11 @@ Versions with only mechanical changes will be omitted from the following list.

* Add `DurationRound` trait that allows rounding and truncating by `Duration` (@robyoung)

### Internal Improvements

* Code improvements to impl `From` for `js_sys` in wasm to reuse code (@schrieveslaach)


## 0.4.12

### New Methods and impls
Expand Down
2 changes: 1 addition & 1 deletion Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -52,7 +52,7 @@ criterion = { version = "0.3" }
doc-comment = { version = "0.3" }

[target.'cfg(all(target_arch = "wasm32", not(any(target_os = "emscripten", target_os = "wasi"))))'.dev-dependencies]
wasm-bindgen-test = "0.2"
wasm-bindgen-test = "0.3"

[package.metadata.docs.rs]
features = ["serde"]
Expand Down
5 changes: 2 additions & 3 deletions ci/github.sh
Original file line number Diff line number Diff line change
Expand Up @@ -91,9 +91,8 @@ test_wasm() {

test_wasm_simple() {
now=$(date +%s)
for tz in "${TEST_TZS[@]}"; do
runt env TZ="$tz" NOW="$now" wasm-pack test --node -- --features wasmbind
done
tz=$(date +%z)
runt env TZ="$tz" NOW="$now" wasm-pack test --node -- --features wasmbind
}

main "$@"
16 changes: 6 additions & 10 deletions src/datetime.rs
Original file line number Diff line number Diff line change
Expand Up @@ -753,22 +753,18 @@ impl<Tz: TimeZone> From<DateTime<Tz>> for SystemTime {
#[cfg(all(target_arch = "wasm32", not(target_os = "wasi"), feature = "wasmbind"))]
impl From<js_sys::Date> for DateTime<Utc> {
fn from(date: js_sys::Date) -> DateTime<Utc> {
let time = date.get_time() as i64;
DateTime::<Utc>::from_utc(
NaiveDateTime::from_timestamp(time / 1000, ((time % 1000) * 1_000_000) as u32),
Utc,
)
DateTime::<Utc>::from(&date)
}
}

#[cfg(all(target_arch = "wasm32", not(target_os = "wasi"), feature = "wasmbind"))]
impl From<&js_sys::Date> for DateTime<Utc> {
fn from(date: &js_sys::Date) -> DateTime<Utc> {
let time = date.get_time() as i64;
DateTime::<Utc>::from_utc(
NaiveDateTime::from_timestamp(time / 1000, ((time % 1000) * 1_000_000) as u32),
Utc,
)
let millisecs_since_unix_epoch: u64 = date.get_time() as u64;
let secs = millisecs_since_unix_epoch / 1000;
let nanos = 1_000_000 * (millisecs_since_unix_epoch % 1000);
let naive = NaiveDateTime::from_timestamp(secs as i64, nanos as u32);
DateTime::from_utc(naive, Utc)
}
}

Expand Down
6 changes: 1 addition & 5 deletions src/offset/utc.rs
Original file line number Diff line number Diff line change
Expand Up @@ -54,11 +54,7 @@ impl Utc {
#[cfg(all(target_arch = "wasm32", not(target_os = "wasi"), feature = "wasmbind"))]
pub fn now() -> DateTime<Utc> {
let now = js_sys::Date::new_0();
let millisecs_since_unix_epoch: u64 = now.get_time() as u64;
let secs = millisecs_since_unix_epoch / 1000;
let nanos = 1_000_000 * (millisecs_since_unix_epoch - 1000 * secs);
let naive = NaiveDateTime::from_timestamp(secs as i64, nanos as u32);
DateTime::from_utc(naive, Utc)
DateTime::<Utc>::from(now)
}
}

Expand Down
31 changes: 25 additions & 6 deletions tests/wasm.rs
Original file line number Diff line number Diff line change
Expand Up @@ -12,17 +12,36 @@ mod test {
let local: DateTime<Local> = Local::now();

// Ensure time fetched is correct
let actual = Utc.datetime_from_str(env!("NOW"), "%s").unwrap();
let actual = Utc.datetime_from_str(&env!("NOW"), "%s").unwrap();
assert!(utc - actual < chrono::Duration::minutes(5));

let tz = env!("TZ");
eprintln!("testing with tz={}", tz);

// Ensure offset retrieved when getting local time is correct
let expected_offset = match env!("TZ") {
let expected_offset = match tz {
"ACST-9:30" => FixedOffset::east(19 * 30 * 60),
"Asia/Katmandu" => FixedOffset::east(23 * 15 * 60), // No DST thankfully
"EST4" => FixedOffset::east(-4 * 60 * 60),
"UTC0" => FixedOffset::east(0),
_ => panic!("unexpected TZ"),
"EDT" | "EST4" | "-0400" => FixedOffset::east(-4 * 60 * 60),
"EST" | "-0500" => FixedOffset::east(-5 * 60 * 60),
"UTC0" | "+0000" => FixedOffset::east(0),
tz => panic!("unexpected TZ {}", tz),
};
assert_eq!(&expected_offset, local.offset());
assert_eq!(
&expected_offset,
local.offset(),
"expected: {:?} local: {:?}",
expected_offset,
local.offset(),
);
}

#[wasm_bindgen_test]
fn from_is_exact() {
let now = js_sys::Date::new_0();

let dt = DateTime::<Utc>::from(now.clone());

assert_eq!(now.get_time() as i64, dt.timestamp_millis());
}
}

0 comments on commit 6be7be3

Please sign in to comment.