Compare commits
No commits in common. "main" and "mute-accounts" have entirely different histories.
main
...
mute-accou
31 changed files with 136 additions and 157 deletions
|
@ -3,61 +3,28 @@ matrix:
|
||||||
|
|
||||||
pipeline:
|
pipeline:
|
||||||
|
|
||||||
check-formatting:
|
|
||||||
image: rust
|
|
||||||
when:
|
|
||||||
branch: [ main ]
|
|
||||||
path:
|
|
||||||
include:
|
|
||||||
- .woodpecker.yml
|
|
||||||
- src/**/*.rs
|
|
||||||
- fedimovies-cli/**/*.rs
|
|
||||||
- fedimovies-config/**/*.rs
|
|
||||||
- fedimovies-models/**/*.rs
|
|
||||||
- fedimovies-utils/**/*.rs
|
|
||||||
environment:
|
|
||||||
- CARGO_TERM_COLOR=always
|
|
||||||
- CARGO_REGISTRIES_CRATES_IO_PROTOCOL=sparse
|
|
||||||
commands:
|
|
||||||
- rustup default $RUST
|
|
||||||
- rustup component add rustfmt
|
|
||||||
- cargo fmt --all -- --check
|
|
||||||
|
|
||||||
check-style:
|
check-style:
|
||||||
image: rust
|
image: rust
|
||||||
when:
|
when:
|
||||||
branch: [ main ]
|
branch: [ master ]
|
||||||
path:
|
path:
|
||||||
include:
|
include:
|
||||||
- .woodpecker.yml
|
|
||||||
- src/**/*.rs
|
- src/**/*.rs
|
||||||
- fedimovies-cli/**/*.rs
|
- fedimovies-*/**/*.rs
|
||||||
- fedimovies-config/**/*.rs
|
|
||||||
- fedimovies-models/**/*.rs
|
|
||||||
- fedimovies-utils/**/*.rs
|
|
||||||
environment:
|
|
||||||
- CARGO_TERM_COLOR=always
|
|
||||||
- CARGO_REGISTRIES_CRATES_IO_PROTOCOL=sparse
|
|
||||||
commands:
|
commands:
|
||||||
- rustup default $RUST
|
- rustup default $RUST
|
||||||
- rustup component add clippy
|
|
||||||
- cargo clippy --all-targets --all-features -- -D warnings
|
- cargo clippy --all-targets --all-features -- -D warnings
|
||||||
|
|
||||||
run-tests:
|
run-tests:
|
||||||
image: rust
|
image: rust
|
||||||
when:
|
when:
|
||||||
branch: [ main ]
|
branch: [ master ]
|
||||||
path:
|
path:
|
||||||
include:
|
include:
|
||||||
- .woodpecker.yml
|
|
||||||
- src/**/*.rs
|
- src/**/*.rs
|
||||||
- fedimovies-cli/**/*.rs
|
- fedimovies-*/**/*.rs
|
||||||
- fedimovies-config/**/*.rs
|
|
||||||
- fedimovies-models/**/*.rs
|
|
||||||
- fedimovies-utils/**/*.rs
|
|
||||||
environment:
|
environment:
|
||||||
- CARGO_TERM_COLOR=always
|
- CARGO_TERM_COLOR=always
|
||||||
- CARGO_REGISTRIES_CRATES_IO_PROTOCOL=sparse
|
|
||||||
commands:
|
commands:
|
||||||
- rustup default $RUST
|
- rustup default $RUST
|
||||||
- cargo test --all -- --nocapture
|
- cargo test --all -- --nocapture
|
||||||
|
|
|
@ -25,8 +25,11 @@ async fn main() {
|
||||||
}
|
}
|
||||||
|
|
||||||
let db_config = config.database_url.parse().unwrap();
|
let db_config = config.database_url.parse().unwrap();
|
||||||
let db_client =
|
let db_client = &mut create_database_client(
|
||||||
&mut create_database_client(&db_config, config.tls_ca_file.as_deref()).await;
|
&db_config,
|
||||||
|
config.tls_ca_file.as_ref().map(|p| p.as_path()),
|
||||||
|
)
|
||||||
|
.await;
|
||||||
apply_migrations(db_client).await;
|
apply_migrations(db_client).await;
|
||||||
|
|
||||||
match subcmd {
|
match subcmd {
|
||||||
|
|
|
@ -127,6 +127,6 @@ mod tests {
|
||||||
assert_eq!(attachment.file_name, file_name);
|
assert_eq!(attachment.file_name, file_name);
|
||||||
assert_eq!(attachment.file_size.unwrap(), file_size as i32);
|
assert_eq!(attachment.file_size.unwrap(), file_size as i32);
|
||||||
assert_eq!(attachment.media_type.unwrap(), media_type);
|
assert_eq!(attachment.media_type.unwrap(), media_type);
|
||||||
assert!(attachment.post_id.is_none());
|
assert_eq!(attachment.post_id.is_none(), true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,6 +14,7 @@ pub mod test_utils;
|
||||||
|
|
||||||
pub type DbPool = deadpool_postgres::Pool;
|
pub type DbPool = deadpool_postgres::Pool;
|
||||||
pub use tokio_postgres::GenericClient as DatabaseClient;
|
pub use tokio_postgres::GenericClient as DatabaseClient;
|
||||||
|
use tokio_postgres::NoTls;
|
||||||
|
|
||||||
#[derive(thiserror::Error, Debug)]
|
#[derive(thiserror::Error, Debug)]
|
||||||
#[error("database type error")]
|
#[error("database type error")]
|
||||||
|
@ -80,10 +81,7 @@ pub fn create_pool(database_url: &str, ca_file_path: Option<&Path>, pool_size: u
|
||||||
connector,
|
connector,
|
||||||
)
|
)
|
||||||
} else {
|
} else {
|
||||||
deadpool_postgres::Manager::new(
|
deadpool_postgres::Manager::new(database_url.parse().expect("invalid database URL"), NoTls)
|
||||||
database_url.parse().expect("invalid database URL"),
|
|
||||||
tokio_postgres::NoTls,
|
|
||||||
)
|
|
||||||
};
|
};
|
||||||
|
|
||||||
DbPool::builder(manager)
|
DbPool::builder(manager)
|
||||||
|
|
|
@ -3,7 +3,8 @@ use super::migrate::apply_migrations;
|
||||||
use tokio_postgres::config::Config;
|
use tokio_postgres::config::Config;
|
||||||
use tokio_postgres::Client;
|
use tokio_postgres::Client;
|
||||||
|
|
||||||
const DEFAULT_CONNECTION_URL: &str = "postgres://fedimovies:fedimovies@127.0.0.1:55432/fedimovies";
|
const DEFAULT_CONNECTION_URL: &str =
|
||||||
|
"postgres://fedimovies:fedimovies@127.0.0.1:55432/fedimovies-test";
|
||||||
|
|
||||||
pub async fn create_test_database() -> Client {
|
pub async fn create_test_database() -> Client {
|
||||||
let connection_url =
|
let connection_url =
|
||||||
|
@ -18,7 +19,7 @@ pub async fn create_test_database() -> Client {
|
||||||
|
|
||||||
// Create connection without database name
|
// Create connection without database name
|
||||||
db_config.dbname("");
|
db_config.dbname("");
|
||||||
let db_client = create_database_client(&db_config, None).await;
|
let db_client = create_database_client(&db_config).await;
|
||||||
let drop_db_statement = format!("DROP DATABASE IF EXISTS {db_name:?}", db_name = db_name,);
|
let drop_db_statement = format!("DROP DATABASE IF EXISTS {db_name:?}", db_name = db_name,);
|
||||||
db_client.execute(&drop_db_statement, &[]).await.unwrap();
|
db_client.execute(&drop_db_statement, &[]).await.unwrap();
|
||||||
let create_db_statement = format!(
|
let create_db_statement = format!(
|
||||||
|
@ -30,7 +31,7 @@ pub async fn create_test_database() -> Client {
|
||||||
|
|
||||||
// Create new connection to database
|
// Create new connection to database
|
||||||
db_config.dbname(&db_name);
|
db_config.dbname(&db_name);
|
||||||
let mut db_client = create_database_client(&db_config, None).await;
|
let mut db_client = create_database_client(&db_config).await;
|
||||||
apply_migrations(&mut db_client).await;
|
apply_migrations(&mut db_client).await;
|
||||||
db_client
|
db_client
|
||||||
}
|
}
|
||||||
|
|
|
@ -172,7 +172,7 @@ mod tests {
|
||||||
let post = create_post(db_client, &author.id, post_data).await.unwrap();
|
let post = create_post(db_client, &author.id, post_data).await.unwrap();
|
||||||
let reply_data = PostCreateData {
|
let reply_data = PostCreateData {
|
||||||
content: "reply".to_string(),
|
content: "reply".to_string(),
|
||||||
in_reply_to_id: Some(post.id),
|
in_reply_to_id: Some(post.id.clone()),
|
||||||
..Default::default()
|
..Default::default()
|
||||||
};
|
};
|
||||||
let mut reply = create_post(db_client, &author.id, reply_data)
|
let mut reply = create_post(db_client, &author.id, reply_data)
|
||||||
|
@ -182,8 +182,8 @@ mod tests {
|
||||||
.await
|
.await
|
||||||
.unwrap();
|
.unwrap();
|
||||||
assert_eq!(reply.in_reply_to.unwrap().id, post.id);
|
assert_eq!(reply.in_reply_to.unwrap().id, post.id);
|
||||||
assert!(reply.repost_of.is_none());
|
assert_eq!(reply.repost_of.is_none(), true);
|
||||||
assert!(reply.linked.is_empty());
|
assert_eq!(reply.linked.is_empty(), true);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[tokio::test]
|
#[tokio::test]
|
||||||
|
@ -195,7 +195,7 @@ mod tests {
|
||||||
};
|
};
|
||||||
let db_client = &create_test_database().await;
|
let db_client = &create_test_database().await;
|
||||||
let result = can_view_post(db_client, None, &post).await.unwrap();
|
let result = can_view_post(db_client, None, &post).await.unwrap();
|
||||||
assert!(result);
|
assert_eq!(result, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[tokio::test]
|
#[tokio::test]
|
||||||
|
@ -208,7 +208,7 @@ mod tests {
|
||||||
};
|
};
|
||||||
let db_client = &create_test_database().await;
|
let db_client = &create_test_database().await;
|
||||||
let result = can_view_post(db_client, Some(&user), &post).await.unwrap();
|
let result = can_view_post(db_client, Some(&user), &post).await.unwrap();
|
||||||
assert!(!result);
|
assert_eq!(result, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[tokio::test]
|
#[tokio::test]
|
||||||
|
@ -222,7 +222,7 @@ mod tests {
|
||||||
};
|
};
|
||||||
let db_client = &create_test_database().await;
|
let db_client = &create_test_database().await;
|
||||||
let result = can_view_post(db_client, Some(&user), &post).await.unwrap();
|
let result = can_view_post(db_client, Some(&user), &post).await.unwrap();
|
||||||
assert!(result);
|
assert_eq!(result, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[tokio::test]
|
#[tokio::test]
|
||||||
|
@ -236,7 +236,7 @@ mod tests {
|
||||||
..Default::default()
|
..Default::default()
|
||||||
};
|
};
|
||||||
let result = can_view_post(db_client, None, &post).await.unwrap();
|
let result = can_view_post(db_client, None, &post).await.unwrap();
|
||||||
assert!(!result);
|
assert_eq!(result, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[tokio::test]
|
#[tokio::test]
|
||||||
|
@ -254,7 +254,7 @@ mod tests {
|
||||||
let result = can_view_post(db_client, Some(&follower), &post)
|
let result = can_view_post(db_client, Some(&follower), &post)
|
||||||
.await
|
.await
|
||||||
.unwrap();
|
.unwrap();
|
||||||
assert!(result);
|
assert_eq!(result, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[tokio::test]
|
#[tokio::test]
|
||||||
|
@ -274,13 +274,19 @@ mod tests {
|
||||||
mentions: vec![subscriber.profile.clone()],
|
mentions: vec![subscriber.profile.clone()],
|
||||||
..Default::default()
|
..Default::default()
|
||||||
};
|
};
|
||||||
assert!(!can_view_post(db_client, None, &post).await.unwrap(),);
|
assert_eq!(can_view_post(db_client, None, &post).await.unwrap(), false,);
|
||||||
assert!(!can_view_post(db_client, Some(&follower), &post)
|
assert_eq!(
|
||||||
.await
|
can_view_post(db_client, Some(&follower), &post)
|
||||||
.unwrap(),);
|
.await
|
||||||
assert!(can_view_post(db_client, Some(&subscriber), &post)
|
.unwrap(),
|
||||||
.await
|
false,
|
||||||
.unwrap(),);
|
);
|
||||||
|
assert_eq!(
|
||||||
|
can_view_post(db_client, Some(&subscriber), &post)
|
||||||
|
.await
|
||||||
|
.unwrap(),
|
||||||
|
true,
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
@ -289,8 +295,8 @@ mod tests {
|
||||||
role: Role::NormalUser,
|
role: Role::NormalUser,
|
||||||
..Default::default()
|
..Default::default()
|
||||||
};
|
};
|
||||||
assert!(can_create_post(&user));
|
assert_eq!(can_create_post(&user), true);
|
||||||
user.role = Role::ReadOnlyUser;
|
user.role = Role::ReadOnlyUser;
|
||||||
assert!(!can_create_post(&user));
|
assert_eq!(can_create_post(&user), false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1348,10 +1348,10 @@ mod tests {
|
||||||
let post = create_post(db_client, &author.id, post_data).await.unwrap();
|
let post = create_post(db_client, &author.id, post_data).await.unwrap();
|
||||||
assert_eq!(post.content, "test post");
|
assert_eq!(post.content, "test post");
|
||||||
assert_eq!(post.author.id, author.id);
|
assert_eq!(post.author.id, author.id);
|
||||||
assert!(post.attachments.is_empty());
|
assert_eq!(post.attachments.is_empty(), true);
|
||||||
assert!(post.mentions.is_empty());
|
assert_eq!(post.mentions.is_empty(), true);
|
||||||
assert!(post.tags.is_empty());
|
assert_eq!(post.tags.is_empty(), true);
|
||||||
assert!(post.links.is_empty());
|
assert_eq!(post.links.is_empty(), true);
|
||||||
assert_eq!(post.updated_at, None);
|
assert_eq!(post.updated_at, None);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1401,7 +1401,7 @@ mod tests {
|
||||||
update_post(db_client, &post.id, post_data).await.unwrap();
|
update_post(db_client, &post.id, post_data).await.unwrap();
|
||||||
let post = get_post_by_id(db_client, &post.id).await.unwrap();
|
let post = get_post_by_id(db_client, &post.id).await.unwrap();
|
||||||
assert_eq!(post.content, "test update");
|
assert_eq!(post.content, "test update");
|
||||||
assert!(post.updated_at.is_some());
|
assert_eq!(post.updated_at.is_some(), true);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[tokio::test]
|
#[tokio::test]
|
||||||
|
@ -1590,19 +1590,19 @@ mod tests {
|
||||||
.await
|
.await
|
||||||
.unwrap();
|
.unwrap();
|
||||||
assert_eq!(timeline.len(), 7);
|
assert_eq!(timeline.len(), 7);
|
||||||
assert!(timeline.iter().any(|post| post.id == post_1.id));
|
assert_eq!(timeline.iter().any(|post| post.id == post_1.id), true);
|
||||||
assert!(timeline.iter().any(|post| post.id == post_2.id));
|
assert_eq!(timeline.iter().any(|post| post.id == post_2.id), true);
|
||||||
assert!(!timeline.iter().any(|post| post.id == post_3.id));
|
assert_eq!(timeline.iter().any(|post| post.id == post_3.id), false);
|
||||||
assert!(timeline.iter().any(|post| post.id == post_4.id));
|
assert_eq!(timeline.iter().any(|post| post.id == post_4.id), true);
|
||||||
assert!(!timeline.iter().any(|post| post.id == post_5.id));
|
assert_eq!(timeline.iter().any(|post| post.id == post_5.id), false);
|
||||||
assert!(timeline.iter().any(|post| post.id == post_6.id));
|
assert_eq!(timeline.iter().any(|post| post.id == post_6.id), true);
|
||||||
assert!(timeline.iter().any(|post| post.id == post_7.id));
|
assert_eq!(timeline.iter().any(|post| post.id == post_7.id), true);
|
||||||
assert!(!timeline.iter().any(|post| post.id == post_8.id));
|
assert_eq!(timeline.iter().any(|post| post.id == post_8.id), false);
|
||||||
assert!(timeline.iter().any(|post| post.id == post_9.id));
|
assert_eq!(timeline.iter().any(|post| post.id == post_9.id), true);
|
||||||
assert!(!timeline.iter().any(|post| post.id == post_10.id));
|
assert_eq!(timeline.iter().any(|post| post.id == post_10.id), false);
|
||||||
assert!(!timeline.iter().any(|post| post.id == post_11.id));
|
assert_eq!(timeline.iter().any(|post| post.id == post_11.id), false);
|
||||||
assert!(timeline.iter().any(|post| post.id == post_12.id));
|
assert_eq!(timeline.iter().any(|post| post.id == post_12.id), true);
|
||||||
assert!(!timeline.iter().any(|post| post.id == post_13.id));
|
assert_eq!(timeline.iter().any(|post| post.id == post_13.id), false);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[tokio::test]
|
#[tokio::test]
|
||||||
|
@ -1645,13 +1645,13 @@ mod tests {
|
||||||
// Reply
|
// Reply
|
||||||
let reply_data = PostCreateData {
|
let reply_data = PostCreateData {
|
||||||
content: "my reply".to_string(),
|
content: "my reply".to_string(),
|
||||||
in_reply_to_id: Some(post_1.id),
|
in_reply_to_id: Some(post_1.id.clone()),
|
||||||
..Default::default()
|
..Default::default()
|
||||||
};
|
};
|
||||||
let reply = create_post(db_client, &user.id, reply_data).await.unwrap();
|
let reply = create_post(db_client, &user.id, reply_data).await.unwrap();
|
||||||
// Repost
|
// Repost
|
||||||
let repost_data = PostCreateData {
|
let repost_data = PostCreateData {
|
||||||
repost_of_id: Some(reply.id),
|
repost_of_id: Some(reply.id.clone()),
|
||||||
..Default::default()
|
..Default::default()
|
||||||
};
|
};
|
||||||
let repost = create_post(db_client, &user.id, repost_data).await.unwrap();
|
let repost = create_post(db_client, &user.id, repost_data).await.unwrap();
|
||||||
|
@ -1661,12 +1661,12 @@ mod tests {
|
||||||
.await
|
.await
|
||||||
.unwrap();
|
.unwrap();
|
||||||
assert_eq!(timeline.len(), 2);
|
assert_eq!(timeline.len(), 2);
|
||||||
assert!(timeline.iter().any(|post| post.id == post_1.id));
|
assert_eq!(timeline.iter().any(|post| post.id == post_1.id), true);
|
||||||
assert!(!timeline.iter().any(|post| post.id == post_2.id));
|
assert_eq!(timeline.iter().any(|post| post.id == post_2.id), false);
|
||||||
assert!(!timeline.iter().any(|post| post.id == post_3.id));
|
assert_eq!(timeline.iter().any(|post| post.id == post_3.id), false);
|
||||||
assert!(!timeline.iter().any(|post| post.id == post_4.id));
|
assert_eq!(timeline.iter().any(|post| post.id == post_4.id), false);
|
||||||
assert!(!timeline.iter().any(|post| post.id == reply.id));
|
assert_eq!(timeline.iter().any(|post| post.id == reply.id), false);
|
||||||
assert!(timeline.iter().any(|post| post.id == repost.id));
|
assert_eq!(timeline.iter().any(|post| post.id == repost.id), true);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[tokio::test]
|
#[tokio::test]
|
||||||
|
@ -1686,7 +1686,7 @@ mod tests {
|
||||||
let post_1 = create_post(db_client, &user.id, post_data_1).await.unwrap();
|
let post_1 = create_post(db_client, &user.id, post_data_1).await.unwrap();
|
||||||
let post_data_2 = PostCreateData {
|
let post_data_2 = PostCreateData {
|
||||||
content: "my reply".to_string(),
|
content: "my reply".to_string(),
|
||||||
in_reply_to_id: Some(post_1.id),
|
in_reply_to_id: Some(post_1.id.clone()),
|
||||||
..Default::default()
|
..Default::default()
|
||||||
};
|
};
|
||||||
let post_2 = create_post(db_client, &user.id, post_data_2).await.unwrap();
|
let post_2 = create_post(db_client, &user.id, post_data_2).await.unwrap();
|
||||||
|
|
|
@ -932,7 +932,7 @@ mod tests {
|
||||||
.unwrap();
|
.unwrap();
|
||||||
let profile_data = ProfileCreateData {
|
let profile_data = ProfileCreateData {
|
||||||
username: "test".to_string(),
|
username: "test".to_string(),
|
||||||
emojis: vec![emoji.id],
|
emojis: vec![emoji.id.clone()],
|
||||||
..Default::default()
|
..Default::default()
|
||||||
};
|
};
|
||||||
let profile = create_profile(db_client, profile_data).await.unwrap();
|
let profile = create_profile(db_client, profile_data).await.unwrap();
|
||||||
|
@ -1078,7 +1078,7 @@ mod tests {
|
||||||
.await
|
.await
|
||||||
.unwrap();
|
.unwrap();
|
||||||
let profile = get_profile_by_id(db_client, &profile.id).await.unwrap();
|
let profile = get_profile_by_id(db_client, &profile.id).await.unwrap();
|
||||||
assert!(profile.unreachable_since.is_some());
|
assert_eq!(profile.unreachable_since.is_some(), true);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[tokio::test]
|
#[tokio::test]
|
||||||
|
@ -1089,6 +1089,6 @@ mod tests {
|
||||||
let profiles = find_empty_profiles(db_client, &updated_before)
|
let profiles = find_empty_profiles(db_client, &updated_before)
|
||||||
.await
|
.await
|
||||||
.unwrap();
|
.unwrap();
|
||||||
assert!(profiles.is_empty());
|
assert_eq!(profiles.is_empty(), true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -727,7 +727,7 @@ mod tests {
|
||||||
let target_has_followers = has_local_followers(db_client, target_actor_id)
|
let target_has_followers = has_local_followers(db_client, target_actor_id)
|
||||||
.await
|
.await
|
||||||
.unwrap();
|
.unwrap();
|
||||||
assert!(target_has_followers);
|
assert_eq!(target_has_followers, true);
|
||||||
|
|
||||||
// Unfollow
|
// Unfollow
|
||||||
let follow_request_id = unfollow(db_client, &source.id, &target.id)
|
let follow_request_id = unfollow(db_client, &source.id, &target.id)
|
||||||
|
|
|
@ -249,6 +249,6 @@ mod tests {
|
||||||
)
|
)
|
||||||
.await
|
.await
|
||||||
.unwrap();
|
.unwrap();
|
||||||
assert!(is_subscribed);
|
assert_eq!(is_subscribed, true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -420,7 +420,7 @@ mod tests {
|
||||||
..Default::default()
|
..Default::default()
|
||||||
};
|
};
|
||||||
let user = create_user(db_client, user_data).await.unwrap();
|
let user = create_user(db_client, user_data).await.unwrap();
|
||||||
assert!(user.client_config.is_empty());
|
assert_eq!(user.client_config.is_empty(), true);
|
||||||
let client_name = "test";
|
let client_name = "test";
|
||||||
let client_config_value = json!({"a": 1});
|
let client_config_value = json!({"a": 1});
|
||||||
let client_config =
|
let client_config =
|
||||||
|
|
|
@ -85,8 +85,8 @@ mod tests {
|
||||||
fn test_deserialize_public_key_nowrap() {
|
fn test_deserialize_public_key_nowrap() {
|
||||||
let public_key_pem = "-----BEGIN PUBLIC KEY-----\nMIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQC8ehqQ7n6+pw19U8q2UtxE/9017STW3yRnnqV5nVk8LJ00ba+berqwekxDW+nw77GAu3TJ+hYeeSerUNPup7y3yO3V
|
let public_key_pem = "-----BEGIN PUBLIC KEY-----\nMIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQC8ehqQ7n6+pw19U8q2UtxE/9017STW3yRnnqV5nVk8LJ00ba+berqwekxDW+nw77GAu3TJ+hYeeSerUNPup7y3yO3V
|
||||||
YsFtrgWDQ/s8k86sNBU+Ce2GOL7seh46kyAWgJeohh4Rcrr23rftHbvxOcRM8VzYuCeb1DgVhPGtA0xULwIDAQAB\n-----END PUBLIC KEY-----";
|
YsFtrgWDQ/s8k86sNBU+Ce2GOL7seh46kyAWgJeohh4Rcrr23rftHbvxOcRM8VzYuCeb1DgVhPGtA0xULwIDAQAB\n-----END PUBLIC KEY-----";
|
||||||
let result = deserialize_public_key(public_key_pem);
|
let result = deserialize_public_key(&public_key_pem);
|
||||||
assert!(result.is_ok());
|
assert_eq!(result.is_ok(), true);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
@ -105,6 +105,6 @@ YsFtrgWDQ/s8k86sNBU+Ce2GOL7seh46kyAWgJeohh4Rcrr23rftHbvxOcRM8VzYuCeb1DgVhPGtA0xU
|
||||||
let public_key = RsaPublicKey::from(&private_key);
|
let public_key = RsaPublicKey::from(&private_key);
|
||||||
|
|
||||||
let is_valid = verify_rsa_sha256_signature(&public_key, &message, &signature);
|
let is_valid = verify_rsa_sha256_signature(&public_key, &message, &signature);
|
||||||
assert!(is_valid);
|
assert_eq!(is_valid, true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,6 +20,6 @@ mod tests {
|
||||||
let password = "$test123";
|
let password = "$test123";
|
||||||
let password_hash = hash_password(password).unwrap();
|
let password_hash = hash_password(password).unwrap();
|
||||||
let result = verify_password(&password_hash, password);
|
let result = verify_password(&password_hash, password);
|
||||||
assert!(result.is_ok());
|
assert_eq!(result.is_ok(), true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -89,7 +89,7 @@ mod tests {
|
||||||
fn test_get_hostname_email() {
|
fn test_get_hostname_email() {
|
||||||
let url = "mailto:user@example.org";
|
let url = "mailto:user@example.org";
|
||||||
let result = get_hostname(url);
|
let result = get_hostname(url);
|
||||||
assert!(result.is_err());
|
assert_eq!(result.is_err(), true);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
|
|
@ -28,7 +28,7 @@ pub fn parse_identity_proof(
|
||||||
_actor_id: &str,
|
_actor_id: &str,
|
||||||
_attachment: &ActorAttachment,
|
_attachment: &ActorAttachment,
|
||||||
) -> Result<IdentityProof, ValidationError> {
|
) -> Result<IdentityProof, ValidationError> {
|
||||||
Err(ValidationError("incorrect proof type".to_string()))
|
return Err(ValidationError("incorrect proof type".to_string()));
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn attach_payment_option(
|
pub fn attach_payment_option(
|
||||||
|
|
|
@ -80,7 +80,7 @@ mod tests {
|
||||||
let follower_id = "https://test.remote/users/123";
|
let follower_id = "https://test.remote/users/123";
|
||||||
let activity = build_accept_follow(INSTANCE_URL, &target, follower_id, follow_activity_id);
|
let activity = build_accept_follow(INSTANCE_URL, &target, follower_id, follow_activity_id);
|
||||||
|
|
||||||
assert!(activity.id.starts_with(INSTANCE_URL));
|
assert_eq!(activity.id.starts_with(INSTANCE_URL), true);
|
||||||
assert_eq!(activity.activity_type, "Accept");
|
assert_eq!(activity.activity_type, "Accept");
|
||||||
assert_eq!(activity.object, follow_activity_id);
|
assert_eq!(activity.object, follow_activity_id);
|
||||||
assert_eq!(activity.to, vec![follower_id]);
|
assert_eq!(activity.to, vec![follower_id]);
|
||||||
|
|
|
@ -117,7 +117,7 @@ mod tests {
|
||||||
};
|
};
|
||||||
let post_id = "https://test.net/obj/123";
|
let post_id = "https://test.net/obj/123";
|
||||||
let post = Post {
|
let post = Post {
|
||||||
author: post_author,
|
author: post_author.clone(),
|
||||||
object_id: Some(post_id.to_string()),
|
object_id: Some(post_id.to_string()),
|
||||||
..Default::default()
|
..Default::default()
|
||||||
};
|
};
|
||||||
|
|
|
@ -339,7 +339,7 @@ mod tests {
|
||||||
note.attributed_to,
|
note.attributed_to,
|
||||||
format!("{}/users/{}", INSTANCE_URL, post.author.username),
|
format!("{}/users/{}", INSTANCE_URL, post.author.username),
|
||||||
);
|
);
|
||||||
assert!(note.in_reply_to.is_none());
|
assert_eq!(note.in_reply_to.is_none(), true);
|
||||||
assert_eq!(note.content, post.content);
|
assert_eq!(note.content, post.content);
|
||||||
assert_eq!(note.to, vec![AP_PUBLIC]);
|
assert_eq!(note.to, vec![AP_PUBLIC]);
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
|
@ -367,7 +367,7 @@ mod tests {
|
||||||
note.to,
|
note.to,
|
||||||
vec![local_actor_followers(INSTANCE_URL, &post.author.username),]
|
vec![local_actor_followers(INSTANCE_URL, &post.author.username),]
|
||||||
);
|
);
|
||||||
assert!(note.cc.is_empty());
|
assert_eq!(note.cc.is_empty(), true);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
@ -397,7 +397,7 @@ mod tests {
|
||||||
subscriber_id.to_string(),
|
subscriber_id.to_string(),
|
||||||
]
|
]
|
||||||
);
|
);
|
||||||
assert!(note.cc.is_empty());
|
assert_eq!(note.cc.is_empty(), true);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
@ -421,7 +421,7 @@ mod tests {
|
||||||
let note = build_note(INSTANCE_HOSTNAME, INSTANCE_URL, &post);
|
let note = build_note(INSTANCE_HOSTNAME, INSTANCE_URL, &post);
|
||||||
|
|
||||||
assert_eq!(note.to, vec![mentioned_id]);
|
assert_eq!(note.to, vec![mentioned_id]);
|
||||||
assert!(note.cc.is_empty());
|
assert_eq!(note.cc.is_empty(), true);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
|
|
@ -129,6 +129,6 @@ mod tests {
|
||||||
);
|
);
|
||||||
assert_eq!(activity.object, post_id);
|
assert_eq!(activity.object, post_id);
|
||||||
assert_eq!(activity.to, vec![post_author_id, AP_PUBLIC]);
|
assert_eq!(activity.to, vec![post_author_id, AP_PUBLIC]);
|
||||||
assert!(activity.cc.is_empty());
|
assert_eq!(activity.cc.is_empty(), true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -357,7 +357,7 @@ mod tests {
|
||||||
HeaderValue::from_static(r#"application/activity+json, application/ld+json; profile="https://www.w3.org/ns/activitystreams", text/html;q=0.1"#),
|
HeaderValue::from_static(r#"application/activity+json, application/ld+json; profile="https://www.w3.org/ns/activitystreams", text/html;q=0.1"#),
|
||||||
);
|
);
|
||||||
let result = is_activitypub_request(&request_headers);
|
let result = is_activitypub_request(&request_headers);
|
||||||
assert!(result);
|
assert_eq!(result, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
@ -368,7 +368,7 @@ mod tests {
|
||||||
HeaderValue::from_static("application/activity+json"),
|
HeaderValue::from_static("application/activity+json"),
|
||||||
);
|
);
|
||||||
let result = is_activitypub_request(&request_headers);
|
let result = is_activitypub_request(&request_headers);
|
||||||
assert!(result);
|
assert_eq!(result, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
@ -376,6 +376,6 @@ mod tests {
|
||||||
let mut request_headers = HeaderMap::new();
|
let mut request_headers = HeaderMap::new();
|
||||||
request_headers.insert(header::ACCEPT, HeaderValue::from_static("text/html"));
|
request_headers.insert(header::ACCEPT, HeaderValue::from_static("text/html"));
|
||||||
let result = is_activitypub_request(&request_headers);
|
let result = is_activitypub_request(&request_headers);
|
||||||
assert!(!result);
|
assert_eq!(result, false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -107,7 +107,10 @@ mod tests {
|
||||||
r#"headers="(request-target) host date","#,
|
r#"headers="(request-target) host date","#,
|
||||||
r#"signature=""#,
|
r#"signature=""#,
|
||||||
);
|
);
|
||||||
assert!(headers.signature.starts_with(expected_signature_header),);
|
assert_eq!(
|
||||||
|
headers.signature.starts_with(expected_signature_header),
|
||||||
|
true,
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
@ -124,7 +127,7 @@ mod tests {
|
||||||
&signer_key,
|
&signer_key,
|
||||||
signer_key_id,
|
signer_key_id,
|
||||||
);
|
);
|
||||||
assert!(result.is_ok());
|
assert_eq!(result.is_ok(), true);
|
||||||
|
|
||||||
let headers = result.unwrap();
|
let headers = result.unwrap();
|
||||||
assert_eq!(headers.host, "example.org");
|
assert_eq!(headers.host, "example.org");
|
||||||
|
@ -138,6 +141,9 @@ mod tests {
|
||||||
r#"headers="(request-target) host date digest","#,
|
r#"headers="(request-target) host date digest","#,
|
||||||
r#"signature=""#,
|
r#"signature=""#,
|
||||||
);
|
);
|
||||||
assert!(headers.signature.starts_with(expected_signature_header),);
|
assert_eq!(
|
||||||
|
headers.signature.starts_with(expected_signature_header),
|
||||||
|
true,
|
||||||
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -183,7 +183,7 @@ mod tests {
|
||||||
request_headers.insert(header::HOST, HeaderValue::from_static("example.com"));
|
request_headers.insert(header::HOST, HeaderValue::from_static("example.com"));
|
||||||
request_headers.insert(
|
request_headers.insert(
|
||||||
HeaderName::from_static("date"),
|
HeaderName::from_static("date"),
|
||||||
HeaderValue::from_str(date).unwrap(),
|
HeaderValue::from_str(&date).unwrap(),
|
||||||
);
|
);
|
||||||
let signature_header = concat!(
|
let signature_header = concat!(
|
||||||
r#"keyId="https://myserver.org/actor#main-key","#,
|
r#"keyId="https://myserver.org/actor#main-key","#,
|
||||||
|
@ -245,6 +245,6 @@ mod tests {
|
||||||
|
|
||||||
let signer_public_key = RsaPublicKey::from(signer_key);
|
let signer_public_key = RsaPublicKey::from(signer_key);
|
||||||
let result = verify_http_signature(&signature_data, &signer_public_key);
|
let result = verify_http_signature(&signature_data, &signer_public_key);
|
||||||
assert!(result.is_ok());
|
assert_eq!(result.is_ok(), true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -80,6 +80,6 @@ mod tests {
|
||||||
assert_eq!(post_metadata.external_url, post_url);
|
assert_eq!(post_metadata.external_url, post_url);
|
||||||
let created_at_attr = &post_metadata.attributes[0];
|
let created_at_attr = &post_metadata.attributes[0];
|
||||||
assert_eq!(created_at_attr.display_type, "date");
|
assert_eq!(created_at_attr.display_type, "date");
|
||||||
assert!(created_at_attr.value.as_i64().is_some());
|
assert_eq!(created_at_attr.value.as_i64().is_some(), true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -120,7 +120,7 @@ pub async fn handle_movies_mentions(
|
||||||
current_user.profile.username,
|
current_user.profile.username,
|
||||||
post_id
|
post_id
|
||||||
);
|
);
|
||||||
delete_notification(&transaction, mention_notification.id).await?;
|
delete_notification(&mut transaction, mention_notification.id).await?;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
Err(err) => return Err(err.into()),
|
Err(err) => return Err(err.into()),
|
||||||
|
@ -131,11 +131,11 @@ pub async fn handle_movies_mentions(
|
||||||
// Federate
|
// Federate
|
||||||
prepare_announce(&transaction, &config.instance(), ¤t_user, &repost)
|
prepare_announce(&transaction, &config.instance(), ¤t_user, &repost)
|
||||||
.await?
|
.await?
|
||||||
.enqueue(&transaction)
|
.enqueue(&mut transaction)
|
||||||
.await?;
|
.await?;
|
||||||
|
|
||||||
// Delete notification to avoid re-processing
|
// Delete notification to avoid re-processing
|
||||||
delete_notification(&transaction, mention_notification.id).await?;
|
delete_notification(&mut transaction, mention_notification.id).await?;
|
||||||
|
|
||||||
log::info!(
|
log::info!(
|
||||||
"Review as Mention of {} reposted with post id {}",
|
"Review as Mention of {} reposted with post id {}",
|
||||||
|
|
|
@ -117,7 +117,6 @@ pub fn verify_rsa_json_signature(
|
||||||
mod tests {
|
mod tests {
|
||||||
use super::*;
|
use super::*;
|
||||||
use crate::json_signatures::create::sign_object;
|
use crate::json_signatures::create::sign_object;
|
||||||
use fedimovies_utils::did_pkh::DidPkh;
|
|
||||||
use fedimovies_utils::{crypto_rsa::generate_weak_rsa_key, currencies::Currency};
|
use fedimovies_utils::{crypto_rsa::generate_weak_rsa_key, currencies::Currency};
|
||||||
use serde_json::json;
|
use serde_json::json;
|
||||||
|
|
||||||
|
@ -145,7 +144,6 @@ mod tests {
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
#[ignore]
|
|
||||||
fn test_create_and_verify_signature() {
|
fn test_create_and_verify_signature() {
|
||||||
let signer_key = generate_weak_rsa_key().unwrap();
|
let signer_key = generate_weak_rsa_key().unwrap();
|
||||||
let signer_key_id = "https://example.org/users/test#main-key";
|
let signer_key_id = "https://example.org/users/test#main-key";
|
||||||
|
@ -171,6 +169,6 @@ mod tests {
|
||||||
|
|
||||||
let signer_public_key = RsaPublicKey::from(signer_key);
|
let signer_public_key = RsaPublicKey::from(signer_key);
|
||||||
let result = verify_rsa_json_signature(&signature_data, &signer_public_key);
|
let result = verify_rsa_json_signature(&signature_data, &signer_public_key);
|
||||||
assert!(result.is_ok());
|
assert_eq!(result.is_ok(), true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -46,7 +46,7 @@ async fn main() -> std::io::Result<()> {
|
||||||
let db_pool_size = num_cpus::get() * 2;
|
let db_pool_size = num_cpus::get() * 2;
|
||||||
let db_pool = create_pool(
|
let db_pool = create_pool(
|
||||||
&config.database_url,
|
&config.database_url,
|
||||||
config.tls_ca_file.as_deref(),
|
config.tls_ca_file.as_ref().map(|s| s.as_path()),
|
||||||
db_pool_size,
|
db_pool_size,
|
||||||
);
|
);
|
||||||
let mut db_client = get_database_client(&db_pool).await.unwrap();
|
let mut db_client = get_database_client(&db_pool).await.unwrap();
|
||||||
|
|
|
@ -124,13 +124,13 @@ mod tests {
|
||||||
.await
|
.await
|
||||||
.unwrap();
|
.unwrap();
|
||||||
assert_eq!(relationship.id, user_2.id);
|
assert_eq!(relationship.id, user_2.id);
|
||||||
assert!(!relationship.following);
|
assert_eq!(relationship.following, false);
|
||||||
assert!(!relationship.followed_by);
|
assert_eq!(relationship.followed_by, false);
|
||||||
assert!(!relationship.requested);
|
assert_eq!(relationship.requested, false);
|
||||||
assert!(!relationship.subscription_to);
|
assert_eq!(relationship.subscription_to, false);
|
||||||
assert!(!relationship.subscription_from);
|
assert_eq!(relationship.subscription_from, false);
|
||||||
assert!(relationship.showing_reblogs);
|
assert_eq!(relationship.showing_reblogs, true);
|
||||||
assert!(relationship.showing_replies);
|
assert_eq!(relationship.showing_replies, true);
|
||||||
// Follow request
|
// Follow request
|
||||||
let follow_request = create_follow_request(db_client, &user_1.id, &user_2.id)
|
let follow_request = create_follow_request(db_client, &user_1.id, &user_2.id)
|
||||||
.await
|
.await
|
||||||
|
@ -138,9 +138,9 @@ mod tests {
|
||||||
let relationship = get_relationship(db_client, &user_1.id, &user_2.id)
|
let relationship = get_relationship(db_client, &user_1.id, &user_2.id)
|
||||||
.await
|
.await
|
||||||
.unwrap();
|
.unwrap();
|
||||||
assert!(!relationship.following);
|
assert_eq!(relationship.following, false);
|
||||||
assert!(!relationship.followed_by);
|
assert_eq!(relationship.followed_by, false);
|
||||||
assert!(relationship.requested);
|
assert_eq!(relationship.requested, true);
|
||||||
// Mutual follow
|
// Mutual follow
|
||||||
follow_request_accepted(db_client, &follow_request.id)
|
follow_request_accepted(db_client, &follow_request.id)
|
||||||
.await
|
.await
|
||||||
|
@ -149,17 +149,17 @@ mod tests {
|
||||||
let relationship = get_relationship(db_client, &user_1.id, &user_2.id)
|
let relationship = get_relationship(db_client, &user_1.id, &user_2.id)
|
||||||
.await
|
.await
|
||||||
.unwrap();
|
.unwrap();
|
||||||
assert!(relationship.following);
|
assert_eq!(relationship.following, true);
|
||||||
assert!(relationship.followed_by);
|
assert_eq!(relationship.followed_by, true);
|
||||||
assert!(!relationship.requested);
|
assert_eq!(relationship.requested, false);
|
||||||
// Unfollow
|
// Unfollow
|
||||||
unfollow(db_client, &user_1.id, &user_2.id).await.unwrap();
|
unfollow(db_client, &user_1.id, &user_2.id).await.unwrap();
|
||||||
let relationship = get_relationship(db_client, &user_1.id, &user_2.id)
|
let relationship = get_relationship(db_client, &user_1.id, &user_2.id)
|
||||||
.await
|
.await
|
||||||
.unwrap();
|
.unwrap();
|
||||||
assert!(!relationship.following);
|
assert_eq!(relationship.following, false);
|
||||||
assert!(relationship.followed_by);
|
assert_eq!(relationship.followed_by, true);
|
||||||
assert!(!relationship.requested);
|
assert_eq!(relationship.requested, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[tokio::test]
|
#[tokio::test]
|
||||||
|
@ -172,8 +172,8 @@ mod tests {
|
||||||
let relationship = get_relationship(db_client, &user_1.id, &user_2.id)
|
let relationship = get_relationship(db_client, &user_1.id, &user_2.id)
|
||||||
.await
|
.await
|
||||||
.unwrap();
|
.unwrap();
|
||||||
assert!(relationship.subscription_to);
|
assert_eq!(relationship.subscription_to, true);
|
||||||
assert!(!relationship.subscription_from);
|
assert_eq!(relationship.subscription_from, false);
|
||||||
|
|
||||||
unsubscribe(db_client, &user_1.id, &user_2.id)
|
unsubscribe(db_client, &user_1.id, &user_2.id)
|
||||||
.await
|
.await
|
||||||
|
@ -181,8 +181,8 @@ mod tests {
|
||||||
let relationship = get_relationship(db_client, &user_1.id, &user_2.id)
|
let relationship = get_relationship(db_client, &user_1.id, &user_2.id)
|
||||||
.await
|
.await
|
||||||
.unwrap();
|
.unwrap();
|
||||||
assert!(!relationship.subscription_to);
|
assert_eq!(relationship.subscription_to, false);
|
||||||
assert!(!relationship.subscription_from);
|
assert_eq!(relationship.subscription_from, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[tokio::test]
|
#[tokio::test]
|
||||||
|
@ -194,8 +194,8 @@ mod tests {
|
||||||
let relationship = get_relationship(db_client, &user_1.id, &user_2.id)
|
let relationship = get_relationship(db_client, &user_1.id, &user_2.id)
|
||||||
.await
|
.await
|
||||||
.unwrap();
|
.unwrap();
|
||||||
assert!(relationship.following);
|
assert_eq!(relationship.following, true);
|
||||||
assert!(relationship.showing_reblogs);
|
assert_eq!(relationship.showing_reblogs, true);
|
||||||
|
|
||||||
hide_reposts(db_client, &user_1.id, &user_2.id)
|
hide_reposts(db_client, &user_1.id, &user_2.id)
|
||||||
.await
|
.await
|
||||||
|
@ -203,8 +203,8 @@ mod tests {
|
||||||
let relationship = get_relationship(db_client, &user_1.id, &user_2.id)
|
let relationship = get_relationship(db_client, &user_1.id, &user_2.id)
|
||||||
.await
|
.await
|
||||||
.unwrap();
|
.unwrap();
|
||||||
assert!(relationship.following);
|
assert_eq!(relationship.following, true);
|
||||||
assert!(!relationship.showing_reblogs);
|
assert_eq!(relationship.showing_reblogs, false);
|
||||||
|
|
||||||
show_reposts(db_client, &user_1.id, &user_2.id)
|
show_reposts(db_client, &user_1.id, &user_2.id)
|
||||||
.await
|
.await
|
||||||
|
@ -212,7 +212,7 @@ mod tests {
|
||||||
let relationship = get_relationship(db_client, &user_1.id, &user_2.id)
|
let relationship = get_relationship(db_client, &user_1.id, &user_2.id)
|
||||||
.await
|
.await
|
||||||
.unwrap();
|
.unwrap();
|
||||||
assert!(relationship.following);
|
assert_eq!(relationship.following, true);
|
||||||
assert!(relationship.showing_reblogs);
|
assert_eq!(relationship.showing_reblogs, true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -115,7 +115,7 @@ mod tests {
|
||||||
let mat = regexp.find(text).unwrap();
|
let mat = regexp.find(text).unwrap();
|
||||||
assert_eq!(mat.start(), 9);
|
assert_eq!(mat.start(), 9);
|
||||||
let result = is_inside_code_block(&mat, text);
|
let result = is_inside_code_block(&mat, text);
|
||||||
assert!(result);
|
assert_eq!(result, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
|
|
@ -41,7 +41,7 @@ mod tests {
|
||||||
fn test_clean_content_empty() {
|
fn test_clean_content_empty() {
|
||||||
let content = " ";
|
let content = " ";
|
||||||
let result = clean_content(content);
|
let result = clean_content(content);
|
||||||
assert!(result.is_err());
|
assert_eq!(result.is_ok(), false);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
|
|
@ -194,6 +194,6 @@ mod tests {
|
||||||
..Default::default()
|
..Default::default()
|
||||||
};
|
};
|
||||||
let result = clean_profile_create_data(&mut profile_data);
|
let result = clean_profile_create_data(&mut profile_data);
|
||||||
assert!(result.is_ok());
|
assert_eq!(result.is_ok(), true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,8 +21,8 @@ mod tests {
|
||||||
#[test]
|
#[test]
|
||||||
fn test_validate_local_username() {
|
fn test_validate_local_username() {
|
||||||
let result_1 = validate_local_username("name_1");
|
let result_1 = validate_local_username("name_1");
|
||||||
assert!(result_1.is_ok());
|
assert_eq!(result_1.is_ok(), true);
|
||||||
let result_2 = validate_local_username("name&");
|
let result_2 = validate_local_username("name&");
|
||||||
assert!(result_2.is_err());
|
assert_eq!(result_2.is_ok(), false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue