about summary refs log tree commit diff stats
path: root/crates/rocie-server/tests/users/mod.rs
blob: df66c64e94ecb53bfb567345f36d9506ce1aec5c (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
// rocie - An enterprise grocery management system
//
// Copyright (C) 2026 Benedikt Peetz <benedikt.peetz@b-peetz.de>
// SPDX-License-Identifier: GPL-3.0-or-later
//
// This file is part of Rocie.
//
// You should have received a copy of the License along with this program.
// If not, see <https://www.gnu.org/licenses/gpl-3.0.txt>.

use rocie_client::{
    apis::{
        api_get_auth_user_api::user_by_id,
        api_set_auth_user_api::register_user,
        api_set_no_auth_user_api::{login, logout, provision},
    },
    models::{LoginInfo, ProvisionInfo, UserStub},
};

use crate::testenv::{TestEnv, init::function_name, log::request};

#[tokio::test]
async fn test_provisioning() {
    let env = TestEnv::new_no_login(function_name!());

    let user_id = request!(
        env,
        provision(ProvisionInfo {
            user: UserStub {
                description: None,
                name: "James Richard Haynes".to_string(),
                password: "hunter14".to_string()
            },
            use_defaults: false,
        })
    );

    let user = request!(env, user_by_id(user_id));

    assert_eq!(&user.name, "James Richard Haynes");
    assert_eq!(user.description, None);
}

#[tokio::test]
async fn test_register_user() {
    let env = TestEnv::new(function_name!()).await;

    let user_id = request!(
        env,
        register_user(UserStub {
            description: Some("Myself".to_string()),
            name: "me".to_string(),
            password: "hunter14".to_string()
        })
    );

    request!(
        @expect_error "The password is wrong"
        env,
        login(LoginInfo {
            user_name: "me".to_owned(),
            password: "hunter13".to_owned()
        })
    );

    request!(
        env,
        login(LoginInfo {
            user_name: "me".to_owned(),
            password: "hunter14".to_owned()
        })
    );

    let user = request!(env, user_by_id(user_id));

    assert_eq!(&user.name, "me");
    assert_eq!(user.description.as_deref(), Some("Myself"));

    request!(env, logout());
    request!(
         @expect_error "We are not logged in anymore"
         env,
         user_by_id(user_id)
    );
}