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
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
pub mod database_admin_client;
#[cfg(test)]
mod tests {
use crate::admin::database::database_admin_client::DatabaseAdminClient;
use chrono::Utc;
use google_cloud_googleapis::spanner::admin::database::v1::database::State;
use google_cloud_googleapis::spanner::admin::database::v1::{
CreateDatabaseRequest, Database, DatabaseDialect, DropDatabaseRequest, GetDatabaseDdlRequest,
GetDatabaseRequest, ListDatabasesRequest, UpdateDatabaseDdlRequest,
};
use serial_test::serial;
async fn create_database() -> Database {
std::env::set_var("SPANNER_EMULATOR_HOST", "localhost:9010");
let client = DatabaseAdminClient::default().await.unwrap();
let database_id = format!("test{}ut", Utc::now().timestamp_nanos());
let request = CreateDatabaseRequest {
parent: "projects/local-project/instances/test-instance".to_string(),
create_statement: format!("CREATE DATABASE {}", database_id),
extra_statements: vec!["CREATE TABLE Tbl (ID STRING(MAX)) PRIMARY KEY(ID)".to_string()],
encryption_config: None,
database_dialect: DatabaseDialect::GoogleStandardSql.into(),
};
let creation_result = match client.create_database(request, None, None).await {
Ok(mut res) => res.wait(None, None).await,
Err(err) => panic!("err: {:?}", err),
};
match creation_result {
Ok(res) => res.unwrap(),
Err(err) => panic!("err: {:?}", err),
}
}
#[tokio::test]
#[serial]
async fn test_create_database() {
let instance = create_database().await;
assert_eq!(instance.state, State::Ready as i32);
}
#[tokio::test]
#[serial]
async fn test_get_database() {
std::env::set_var("SPANNER_EMULATOR_HOST", "localhost:9010");
let client = DatabaseAdminClient::default().await.unwrap();
let name = "projects/local-project/instances/test-instance/databases/local-database".to_string();
let request = GetDatabaseRequest { name: name.clone() };
match client.get_database(request, None, None).await {
Ok(res) => {
let db = res.into_inner();
assert_eq!(db.name, name);
}
Err(err) => panic!("err: {:?}", err),
};
}
#[tokio::test]
#[serial]
async fn test_delete_database() {
let database = create_database().await;
let client = DatabaseAdminClient::default().await.unwrap();
let request = DropDatabaseRequest {
database: database.name.to_string(),
};
let _ = client.drop_database(request, None, None).await.unwrap();
}
#[tokio::test]
#[serial]
async fn test_list_databases() {
std::env::set_var("SPANNER_EMULATOR_HOST", "localhost:9010");
let client = DatabaseAdminClient::default().await.unwrap();
let request = ListDatabasesRequest {
parent: "projects/local-project/instances/test-instance".to_string(),
page_size: 1,
page_token: "".to_string(),
};
match client.list_databases(request, None, None).await {
Ok(res) => {
println!("size = {}", res.len());
assert!(!res.is_empty());
}
Err(err) => panic!("err: {:?}", err),
};
}
#[tokio::test]
#[serial]
async fn test_get_database_ddl() {
let database = create_database().await;
std::env::set_var("SPANNER_EMULATOR_HOST", "localhost:9010");
let client = DatabaseAdminClient::default().await.unwrap();
let request = GetDatabaseDdlRequest {
database: database.name.to_string(),
};
match client.get_database_ddl(request, None, None).await {
Ok(res) => {
assert_eq!(res.into_inner().statements.len(), 1);
}
Err(err) => panic!("err: {:?}", err),
};
}
#[tokio::test]
#[serial]
async fn test_update_database_ddl() {
let database = create_database().await;
std::env::set_var("SPANNER_EMULATOR_HOST", "localhost:9010");
let client = DatabaseAdminClient::default().await.unwrap();
let request = UpdateDatabaseDdlRequest {
database: database.name.to_string(),
statements: vec!["CREATE TABLE Tbl1 (ID INT64) PRIMARY KEY(ID)".to_string()],
operation_id: "".to_string(),
};
let update_result = match client.update_database_ddl(request, None, None).await {
Ok(mut res) => res.wait(None, None).await,
Err(err) => panic!("err: {:?}", err),
};
let _ = update_result.unwrap();
}
}