chore(napi): update tests

Co-authored-by: sup39 <dev@sup39.dev>
This commit is contained in:
naskya 2024-04-30 17:12:30 +09:00
parent 6a9ae1322d
commit 27b64d972c
Signed by: naskya
GPG key ID: 712D413B3A9FED5C
6 changed files with 135 additions and 10 deletions

View file

@ -343,12 +343,26 @@ Generated by [AVA](https://avajs.dev).
export function chronoDateAdd1Minute(input: Date): Date␊ export function chronoDateAdd1Minute(input: Date): Date␊
export function chronoDateToMillis(input: Date): number␊ export function chronoDateFixtureReturn1(): Date␊
export function chronoDateFixtureReturn2(): Date␊
export function chronoDateWithTimezoneReturn(): Date | null␊
export function chronoDateWithTimezoneToMillis(input: Date): number␊
export function chronoLocalDateReturn(): Date | null␊
export function chronoLocalDateToMillis(input: Date): number␊
export function chronoNativeDateTime(date: Date): number␊ export function chronoNativeDateTime(date: Date): number␊
export function chronoNativeDateTimeReturn(): Date | null␊ export function chronoNativeDateTimeReturn(): Date | null␊
export function chronoUtcDateReturn(): Date | null␊
export function chronoUtcDateToMillis(input: Date): number␊
export function concatLatin1(s: string): string␊ export function concatLatin1(s: string): string␊
export function concatStr(s: string): string␊ export function concatStr(s: string): string␊
@ -397,7 +411,7 @@ Generated by [AVA](https://avajs.dev).
export function customStatusCode(): void␊ export function customStatusCode(): void␊
export interface Dates {␊ export interface DatesWithTimeZone {␊
start: Date␊ start: Date␊
end?: Date␊ end?: Date␊
}␊ }␊
@ -505,6 +519,11 @@ Generated by [AVA](https://avajs.dev).
export function listObjKeys(obj: object): Array<string> export function listObjKeys(obj: object): Array<string>
export interface LocalDates {␊
start: Date␊
end?: Date␊
}␊
export function mapOption(val?: number | undefined | null): number | null␊ export function mapOption(val?: number | undefined | null): number | null␊
export function mutateExternal(external: ExternalObject<number>, newVal: number): void␊ export function mutateExternal(external: ExternalObject<number>, newVal: number): void␊
@ -698,6 +717,11 @@ Generated by [AVA](https://avajs.dev).
nullableStringField: string | null␊ nullableStringField: string | null␊
}␊ }␊
export interface UtcDates {␊
start: Date␊
end?: Date␊
}␊
export function validateArray(arr: Array<number>): number␊ export function validateArray(arr: Array<number>): number␊
export function validateBigint(input: bigint): bigint␊ export function validateBigint(input: bigint): bigint␊

View file

@ -126,7 +126,11 @@ import {
createObjWithProperty, createObjWithProperty,
receiveObjectOnlyFromJs, receiveObjectOnlyFromJs,
dateToNumber, dateToNumber,
chronoDateToMillis, chronoUtcDateToMillis,
chronoLocalDateToMillis,
chronoDateWithTimezoneToMillis,
chronoDateFixtureReturn1,
chronoDateFixtureReturn2,
derefUint8Array, derefUint8Array,
chronoDateAdd1Minute, chronoDateAdd1Minute,
bufferPassThrough, bufferPassThrough,
@ -1235,13 +1239,22 @@ Napi5Test('Date test', (t) => {
Napi5Test('Date to chrono test', (t) => { Napi5Test('Date to chrono test', (t) => {
const fixture = new Date('2022-02-09T19:31:55.396Z') const fixture = new Date('2022-02-09T19:31:55.396Z')
t.is(chronoDateToMillis(fixture), fixture.getTime()) t.is(chronoUtcDateToMillis(fixture), fixture.getTime())
t.is(chronoLocalDateToMillis(fixture), fixture.getTime())
t.is(chronoDateWithTimezoneToMillis(fixture), fixture.getTime())
t.deepEqual( t.deepEqual(
chronoDateAdd1Minute(fixture), chronoDateAdd1Minute(fixture),
new Date(fixture.getTime() + 60 * 1000), new Date(fixture.getTime() + 60 * 1000),
) )
}) })
Napi5Test('Get date', (t) => {
const fixture1 = new Date('2024-02-07T18:28:18-0800')
t.deepEqual(chronoDateFixtureReturn1(), fixture1)
const fixture2 = new Date('2024-02-07T18:28:18+0530')
t.deepEqual(chronoDateFixtureReturn2(), fixture2)
})
Napi5Test('Class with getter setter closures', (t) => { Napi5Test('Class with getter setter closures', (t) => {
const instance = new GetterSetterWithClosures() const instance = new GetterSetterWithClosures()
// @ts-expect-error // @ts-expect-error

View file

@ -438,9 +438,16 @@ module.exports.callLongThreadsafeFunction = nativeBinding.callLongThreadsafeFunc
module.exports.callThreadsafeFunction = nativeBinding.callThreadsafeFunction module.exports.callThreadsafeFunction = nativeBinding.callThreadsafeFunction
module.exports.captureErrorInCallback = nativeBinding.captureErrorInCallback module.exports.captureErrorInCallback = nativeBinding.captureErrorInCallback
module.exports.chronoDateAdd1Minute = nativeBinding.chronoDateAdd1Minute module.exports.chronoDateAdd1Minute = nativeBinding.chronoDateAdd1Minute
module.exports.chronoDateToMillis = nativeBinding.chronoDateToMillis module.exports.chronoDateFixtureReturn1 = nativeBinding.chronoDateFixtureReturn1
module.exports.chronoDateFixtureReturn2 = nativeBinding.chronoDateFixtureReturn2
module.exports.chronoDateWithTimezoneReturn = nativeBinding.chronoDateWithTimezoneReturn
module.exports.chronoDateWithTimezoneToMillis = nativeBinding.chronoDateWithTimezoneToMillis
module.exports.chronoLocalDateReturn = nativeBinding.chronoLocalDateReturn
module.exports.chronoLocalDateToMillis = nativeBinding.chronoLocalDateToMillis
module.exports.chronoNativeDateTime = nativeBinding.chronoNativeDateTime module.exports.chronoNativeDateTime = nativeBinding.chronoNativeDateTime
module.exports.chronoNativeDateTimeReturn = nativeBinding.chronoNativeDateTimeReturn module.exports.chronoNativeDateTimeReturn = nativeBinding.chronoNativeDateTimeReturn
module.exports.chronoUtcDateReturn = nativeBinding.chronoUtcDateReturn
module.exports.chronoUtcDateToMillis = nativeBinding.chronoUtcDateToMillis
module.exports.concatLatin1 = nativeBinding.concatLatin1 module.exports.concatLatin1 = nativeBinding.concatLatin1
module.exports.concatStr = nativeBinding.concatStr module.exports.concatStr = nativeBinding.concatStr
module.exports.concatUtf16 = nativeBinding.concatUtf16 module.exports.concatUtf16 = nativeBinding.concatUtf16

View file

@ -333,12 +333,26 @@ export function captureErrorInCallback(cb1: () => void, cb2: (arg0: Error) => vo
export function chronoDateAdd1Minute(input: Date): Date export function chronoDateAdd1Minute(input: Date): Date
export function chronoDateToMillis(input: Date): number export function chronoDateFixtureReturn1(): Date
export function chronoDateFixtureReturn2(): Date
export function chronoDateWithTimezoneReturn(): Date | null
export function chronoDateWithTimezoneToMillis(input: Date): number
export function chronoLocalDateReturn(): Date | null
export function chronoLocalDateToMillis(input: Date): number
export function chronoNativeDateTime(date: Date): number export function chronoNativeDateTime(date: Date): number
export function chronoNativeDateTimeReturn(): Date | null export function chronoNativeDateTimeReturn(): Date | null
export function chronoUtcDateReturn(): Date | null
export function chronoUtcDateToMillis(input: Date): number
export function concatLatin1(s: string): string export function concatLatin1(s: string): string
export function concatStr(s: string): string export function concatStr(s: string): string
@ -387,7 +401,7 @@ export const enum CustomNumEnum {
export function customStatusCode(): void export function customStatusCode(): void
export interface Dates { export interface DatesWithTimeZone {
start: Date start: Date
end?: Date end?: Date
} }
@ -495,6 +509,11 @@ export const enum Kind {
export function listObjKeys(obj: object): Array<string> export function listObjKeys(obj: object): Array<string>
export interface LocalDates {
start: Date
end?: Date
}
export function mapOption(val?: number | undefined | null): number | null export function mapOption(val?: number | undefined | null): number | null
export function mutateExternal(external: ExternalObject<number>, newVal: number): void export function mutateExternal(external: ExternalObject<number>, newVal: number): void
@ -688,6 +707,11 @@ export interface UseNullableStruct {
nullableStringField: string | null nullableStringField: string | null
} }
export interface UtcDates {
start: Date
end?: Date
}
export function validateArray(arr: Array<number>): number export function validateArray(arr: Array<number>): number
export function validateBigint(input: bigint): bigint export function validateBigint(input: bigint): bigint

View file

@ -1,6 +1,6 @@
use std::str::FromStr; use std::str::FromStr;
use chrono::{Duration, Utc}; use chrono::{Duration, FixedOffset, Local, TimeZone, Utc};
use napi::bindgen_prelude::*; use napi::bindgen_prelude::*;
#[napi] #[napi]
@ -9,7 +9,17 @@ fn date_to_number(input: Date) -> Result<f64> {
} }
#[napi] #[napi]
fn chrono_date_to_millis(input: chrono::DateTime<Utc>) -> i64 { fn chrono_utc_date_to_millis(input: chrono::DateTime<Utc>) -> i64 {
input.timestamp_millis()
}
#[napi]
fn chrono_local_date_to_millis(input: chrono::DateTime<Local>) -> i64 {
input.timestamp_millis()
}
#[napi]
fn chrono_date_with_timezone_to_millis(input: chrono::DateTime<FixedOffset>) -> i64 {
input.timestamp_millis() input.timestamp_millis()
} }
@ -19,11 +29,23 @@ fn chrono_date_add_1_minute(input: chrono::DateTime<Utc>) -> chrono::DateTime<Ut
} }
#[napi(object)] #[napi(object)]
pub struct Dates { pub struct UtcDates {
pub start: chrono::DateTime<Utc>, pub start: chrono::DateTime<Utc>,
pub end: Option<chrono::DateTime<Utc>>, pub end: Option<chrono::DateTime<Utc>>,
} }
#[napi(object)]
pub struct LocalDates {
pub start: chrono::DateTime<Local>,
pub end: Option<chrono::DateTime<Local>>,
}
#[napi(object)]
pub struct DatesWithTimeZone {
pub start: chrono::DateTime<FixedOffset>,
pub end: Option<chrono::DateTime<FixedOffset>>,
}
#[napi] #[napi]
pub fn chrono_native_date_time(date: chrono::NaiveDateTime) -> i64 { pub fn chrono_native_date_time(date: chrono::NaiveDateTime) -> i64 {
date.and_utc().timestamp_millis() date.and_utc().timestamp_millis()
@ -33,3 +55,38 @@ pub fn chrono_native_date_time(date: chrono::NaiveDateTime) -> i64 {
pub fn chrono_native_date_time_return() -> Option<chrono::NaiveDateTime> { pub fn chrono_native_date_time_return() -> Option<chrono::NaiveDateTime> {
chrono::NaiveDateTime::from_str("2016-12-23T15:25:59.325").ok() chrono::NaiveDateTime::from_str("2016-12-23T15:25:59.325").ok()
} }
#[napi]
pub fn chrono_utc_date_return() -> Option<chrono::DateTime<Utc>> {
chrono::DateTime::<Utc>::from_str("2016-12-23T15:25:59.325").ok()
}
#[napi]
pub fn chrono_local_date_return() -> Option<chrono::DateTime<Local>> {
chrono::DateTime::<Local>::from_str("2016-12-23T15:25:59.325").ok()
}
#[napi]
pub fn chrono_date_with_timezone_return() -> Option<chrono::DateTime<FixedOffset>> {
chrono::DateTime::<FixedOffset>::from_str("2016-12-23T15:25:59.325").ok()
}
#[napi]
pub fn chrono_date_fixture_return1() -> chrono::DateTime<FixedOffset> {
// Pacific Standard Time: UTC-08:00
let pst = FixedOffset::west_opt(8 * 3600).unwrap();
pst
.with_ymd_and_hms(2024, 2, 7, 18, 28, 18)
.single()
.unwrap()
}
#[napi]
pub fn chrono_date_fixture_return2() -> chrono::DateTime<FixedOffset> {
// Indian Standard Time: UTC+05:30
let ist = FixedOffset::east_opt(5 * 3600 + 30 * 60).unwrap();
ist
.with_ymd_and_hms(2024, 2, 7, 18, 28, 18)
.single()
.unwrap()
}