mirror of
https://tangled.org/tranquil.farm/tranquil-pds
synced 2026-02-11 06:31:06 +00:00
289 lines
7.8 KiB
Rust
289 lines
7.8 KiB
Rust
mod common;
|
|
use common::*;
|
|
|
|
use reqwest::StatusCode;
|
|
use serde_json::{Value, json};
|
|
|
|
#[tokio::test]
|
|
async fn test_create_invite_code_success() {
|
|
let client = client();
|
|
let (access_jwt, _did) = create_account_and_login(&client).await;
|
|
|
|
let payload = json!({
|
|
"useCount": 5
|
|
});
|
|
|
|
let res = client
|
|
.post(format!(
|
|
"{}/xrpc/com.atproto.server.createInviteCode",
|
|
base_url().await
|
|
))
|
|
.bearer_auth(&access_jwt)
|
|
.json(&payload)
|
|
.send()
|
|
.await
|
|
.expect("Failed to send request");
|
|
|
|
assert_eq!(res.status(), StatusCode::OK);
|
|
let body: Value = res.json().await.expect("Response was not valid JSON");
|
|
assert!(body["code"].is_string());
|
|
let code = body["code"].as_str().unwrap();
|
|
assert!(!code.is_empty());
|
|
assert!(code.contains('-'), "Code should be a UUID format");
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn test_create_invite_code_no_auth() {
|
|
let client = client();
|
|
let payload = json!({
|
|
"useCount": 5
|
|
});
|
|
|
|
let res = client
|
|
.post(format!(
|
|
"{}/xrpc/com.atproto.server.createInviteCode",
|
|
base_url().await
|
|
))
|
|
.json(&payload)
|
|
.send()
|
|
.await
|
|
.expect("Failed to send request");
|
|
|
|
assert_eq!(res.status(), StatusCode::UNAUTHORIZED);
|
|
let body: Value = res.json().await.expect("Response was not valid JSON");
|
|
assert_eq!(body["error"], "AuthenticationRequired");
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn test_create_invite_code_invalid_use_count() {
|
|
let client = client();
|
|
let (access_jwt, _did) = create_account_and_login(&client).await;
|
|
|
|
let payload = json!({
|
|
"useCount": 0
|
|
});
|
|
|
|
let res = client
|
|
.post(format!(
|
|
"{}/xrpc/com.atproto.server.createInviteCode",
|
|
base_url().await
|
|
))
|
|
.bearer_auth(&access_jwt)
|
|
.json(&payload)
|
|
.send()
|
|
.await
|
|
.expect("Failed to send request");
|
|
|
|
assert_eq!(res.status(), StatusCode::BAD_REQUEST);
|
|
let body: Value = res.json().await.expect("Response was not valid JSON");
|
|
assert_eq!(body["error"], "InvalidRequest");
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn test_create_invite_code_for_another_account() {
|
|
let client = client();
|
|
let (access_jwt1, _did1) = create_account_and_login(&client).await;
|
|
let (_access_jwt2, did2) = create_account_and_login(&client).await;
|
|
|
|
let payload = json!({
|
|
"useCount": 3,
|
|
"forAccount": did2
|
|
});
|
|
|
|
let res = client
|
|
.post(format!(
|
|
"{}/xrpc/com.atproto.server.createInviteCode",
|
|
base_url().await
|
|
))
|
|
.bearer_auth(&access_jwt1)
|
|
.json(&payload)
|
|
.send()
|
|
.await
|
|
.expect("Failed to send request");
|
|
|
|
assert_eq!(res.status(), StatusCode::OK);
|
|
let body: Value = res.json().await.expect("Response was not valid JSON");
|
|
assert!(body["code"].is_string());
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn test_create_invite_codes_success() {
|
|
let client = client();
|
|
let (access_jwt, _did) = create_account_and_login(&client).await;
|
|
|
|
let payload = json!({
|
|
"useCount": 2,
|
|
"codeCount": 3
|
|
});
|
|
|
|
let res = client
|
|
.post(format!(
|
|
"{}/xrpc/com.atproto.server.createInviteCodes",
|
|
base_url().await
|
|
))
|
|
.bearer_auth(&access_jwt)
|
|
.json(&payload)
|
|
.send()
|
|
.await
|
|
.expect("Failed to send request");
|
|
|
|
assert_eq!(res.status(), StatusCode::OK);
|
|
let body: Value = res.json().await.expect("Response was not valid JSON");
|
|
assert!(body["codes"].is_array());
|
|
let codes = body["codes"].as_array().unwrap();
|
|
assert_eq!(codes.len(), 1);
|
|
assert_eq!(codes[0]["codes"].as_array().unwrap().len(), 3);
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn test_create_invite_codes_for_multiple_accounts() {
|
|
let client = client();
|
|
let (access_jwt1, did1) = create_account_and_login(&client).await;
|
|
let (_access_jwt2, did2) = create_account_and_login(&client).await;
|
|
|
|
let payload = json!({
|
|
"useCount": 1,
|
|
"codeCount": 2,
|
|
"forAccounts": [did1, did2]
|
|
});
|
|
|
|
let res = client
|
|
.post(format!(
|
|
"{}/xrpc/com.atproto.server.createInviteCodes",
|
|
base_url().await
|
|
))
|
|
.bearer_auth(&access_jwt1)
|
|
.json(&payload)
|
|
.send()
|
|
.await
|
|
.expect("Failed to send request");
|
|
|
|
assert_eq!(res.status(), StatusCode::OK);
|
|
let body: Value = res.json().await.expect("Response was not valid JSON");
|
|
let codes = body["codes"].as_array().unwrap();
|
|
assert_eq!(codes.len(), 2);
|
|
|
|
for code_obj in codes {
|
|
assert!(code_obj["account"].is_string());
|
|
assert_eq!(code_obj["codes"].as_array().unwrap().len(), 2);
|
|
}
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn test_create_invite_codes_no_auth() {
|
|
let client = client();
|
|
let payload = json!({
|
|
"useCount": 2
|
|
});
|
|
|
|
let res = client
|
|
.post(format!(
|
|
"{}/xrpc/com.atproto.server.createInviteCodes",
|
|
base_url().await
|
|
))
|
|
.json(&payload)
|
|
.send()
|
|
.await
|
|
.expect("Failed to send request");
|
|
|
|
assert_eq!(res.status(), StatusCode::UNAUTHORIZED);
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn test_get_account_invite_codes_success() {
|
|
let client = client();
|
|
let (access_jwt, _did) = create_account_and_login(&client).await;
|
|
|
|
let create_payload = json!({
|
|
"useCount": 5
|
|
});
|
|
let _ = client
|
|
.post(format!(
|
|
"{}/xrpc/com.atproto.server.createInviteCode",
|
|
base_url().await
|
|
))
|
|
.bearer_auth(&access_jwt)
|
|
.json(&create_payload)
|
|
.send()
|
|
.await
|
|
.expect("Failed to create invite code");
|
|
|
|
let res = client
|
|
.get(format!(
|
|
"{}/xrpc/com.atproto.server.getAccountInviteCodes",
|
|
base_url().await
|
|
))
|
|
.bearer_auth(&access_jwt)
|
|
.send()
|
|
.await
|
|
.expect("Failed to send request");
|
|
|
|
assert_eq!(res.status(), StatusCode::OK);
|
|
let body: Value = res.json().await.expect("Response was not valid JSON");
|
|
assert!(body["codes"].is_array());
|
|
let codes = body["codes"].as_array().unwrap();
|
|
assert!(!codes.is_empty());
|
|
|
|
let code = &codes[0];
|
|
assert!(code["code"].is_string());
|
|
assert!(code["available"].is_number());
|
|
assert!(code["disabled"].is_boolean());
|
|
assert!(code["createdAt"].is_string());
|
|
assert!(code["uses"].is_array());
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn test_get_account_invite_codes_no_auth() {
|
|
let client = client();
|
|
|
|
let res = client
|
|
.get(format!(
|
|
"{}/xrpc/com.atproto.server.getAccountInviteCodes",
|
|
base_url().await
|
|
))
|
|
.send()
|
|
.await
|
|
.expect("Failed to send request");
|
|
|
|
assert_eq!(res.status(), StatusCode::UNAUTHORIZED);
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn test_get_account_invite_codes_include_used_filter() {
|
|
let client = client();
|
|
let (access_jwt, _did) = create_account_and_login(&client).await;
|
|
|
|
let create_payload = json!({
|
|
"useCount": 5
|
|
});
|
|
let _ = client
|
|
.post(format!(
|
|
"{}/xrpc/com.atproto.server.createInviteCode",
|
|
base_url().await
|
|
))
|
|
.bearer_auth(&access_jwt)
|
|
.json(&create_payload)
|
|
.send()
|
|
.await
|
|
.expect("Failed to create invite code");
|
|
|
|
let res = client
|
|
.get(format!(
|
|
"{}/xrpc/com.atproto.server.getAccountInviteCodes",
|
|
base_url().await
|
|
))
|
|
.bearer_auth(&access_jwt)
|
|
.query(&[("includeUsed", "false")])
|
|
.send()
|
|
.await
|
|
.expect("Failed to send request");
|
|
|
|
assert_eq!(res.status(), StatusCode::OK);
|
|
let body: Value = res.json().await.expect("Response was not valid JSON");
|
|
assert!(body["codes"].is_array());
|
|
|
|
for code in body["codes"].as_array().unwrap() {
|
|
assert!(code["available"].as_i64().unwrap() > 0);
|
|
}
|
|
}
|