fix unit test
This commit is contained in:
parent
752d63e6de
commit
a10ade8cf5
3 changed files with 34 additions and 13 deletions
|
@ -7,7 +7,7 @@ version = "0.0.0"
|
||||||
members = ["migration/Cargo.toml"]
|
members = ["migration/Cargo.toml"]
|
||||||
|
|
||||||
[features]
|
[features]
|
||||||
default = ["napi"]
|
default = []
|
||||||
noarray = []
|
noarray = []
|
||||||
napi = ["dep:napi", "dep:napi-derive", "dep:radix_fmt"]
|
napi = ["dep:napi", "dep:napi-derive", "dep:radix_fmt"]
|
||||||
|
|
||||||
|
|
|
@ -41,11 +41,13 @@ cfg_if! {
|
||||||
use napi_derive::napi;
|
use napi_derive::napi;
|
||||||
|
|
||||||
const TIME_2000: u64 = 946_684_800_000;
|
const TIME_2000: u64 = 946_684_800_000;
|
||||||
|
const TIMESTAMP_LENGTH: u16 = 8;
|
||||||
|
|
||||||
/// Calls [init_id] inside. Must be called before [native_create_id].
|
/// Calls [init_id] inside. Must be called before [native_create_id].
|
||||||
#[napi]
|
#[napi]
|
||||||
pub fn native_init_id_generator(length: u16, fingerprint: String) {
|
pub fn native_init_id_generator(length: u16, fingerprint: String) {
|
||||||
init_id(length, fingerprint);
|
// length to pass init_id shoule be greater than or equal to 8.
|
||||||
|
init_id(cmp::max(length - TIMESTAMP_LENGTH, 8), fingerprint);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Generates
|
/// Generates
|
||||||
|
@ -59,19 +61,38 @@ cfg_if! {
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
mod unit_test {
|
mod unit_test {
|
||||||
|
use cfg_if::cfg_if;
|
||||||
use pretty_assertions::{assert_eq, assert_ne};
|
use pretty_assertions::{assert_eq, assert_ne};
|
||||||
use std::thread;
|
use std::thread;
|
||||||
|
|
||||||
use crate::util::id;
|
use crate::util::id;
|
||||||
|
|
||||||
#[test]
|
cfg_if! {
|
||||||
fn can_generate_unique_ids() {
|
if #[cfg(feature = "napi")] {
|
||||||
assert_eq!(id::create_id(), Err(id::ErrorUninitialized));
|
use chrono::Utc;
|
||||||
id::init_id(12, "");
|
|
||||||
assert_eq!(id::create_id().unwrap().len(), 12);
|
#[test]
|
||||||
assert_ne!(id::create_id().unwrap(), id::create_id().unwrap());
|
fn can_generate_aid_compat_ids() {
|
||||||
let id1 = thread::spawn(|| id::create_id().unwrap());
|
id::native_init_id_generator(16, "".to_string());
|
||||||
let id2 = thread::spawn(|| id::create_id().unwrap());
|
let id1 = id::native_create_id(Utc::now().timestamp_millis().into());
|
||||||
assert_ne!(id1.join().unwrap(), id2.join().unwrap())
|
assert_eq!(id1.len(), 16);
|
||||||
|
let id1 = id::native_create_id(Utc::now().timestamp_millis().into());
|
||||||
|
let id2 = id::native_create_id(Utc::now().timestamp_millis().into());
|
||||||
|
assert_ne!(id1, id2);
|
||||||
|
let id1 = thread::spawn(|| id::native_create_id(Utc::now().timestamp_millis().into()));
|
||||||
|
let id2 = thread::spawn(|| id::native_create_id(Utc::now().timestamp_millis().into()));
|
||||||
|
assert_ne!(id1.join().unwrap(), id2.join().unwrap());
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
#[test]
|
||||||
|
fn can_generate_unique_ids() {
|
||||||
|
assert_eq!(id::create_id(), Err(id::ErrorUninitialized));
|
||||||
|
id::init_id(12, "");
|
||||||
|
assert_eq!(id::create_id().unwrap().len(), 12);
|
||||||
|
assert_ne!(id::create_id().unwrap(), id::create_id().unwrap());
|
||||||
|
let id1 = thread::spawn(|| id::create_id().unwrap());
|
||||||
|
let id2 = thread::spawn(|| id::create_id().unwrap());
|
||||||
|
assert_ne!(id1.join().unwrap(), id2.join().unwrap())
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -139,7 +139,7 @@ async fn cleanup() {
|
||||||
}
|
}
|
||||||
|
|
||||||
async fn setup_model(db: &DbConn) {
|
async fn setup_model(db: &DbConn) {
|
||||||
init_id(12);
|
init_id(12, "");
|
||||||
|
|
||||||
db.transaction::<_, (), DbErr>(|txn| {
|
db.transaction::<_, (), DbErr>(|txn| {
|
||||||
Box::pin(async move {
|
Box::pin(async move {
|
||||||
|
|
Loading…
Reference in a new issue