test vm creation timeout
format tests seperated vm tests into its module
This commit is contained in:
		
							parent
							
								
									ea50603a88
								
							
						
					
					
						commit
						519bd1ed7b
					
				| @ -7,8 +7,6 @@ use common::vm_daemon_utils::mock_vm_daemon; | |||||||
| use detee_shared::common_proto::{Empty, Pubkey}; | use detee_shared::common_proto::{Empty, Pubkey}; | ||||||
| use detee_shared::general_proto::brain_general_cli_client::BrainGeneralCliClient; | use detee_shared::general_proto::brain_general_cli_client::BrainGeneralCliClient; | ||||||
| use detee_shared::general_proto::AirdropReq; | use detee_shared::general_proto::AirdropReq; | ||||||
| use detee_shared::vm_proto::brain_vm_cli_client::BrainVmCliClient; |  | ||||||
| use detee_shared::vm_proto::ListVmContractsReq; |  | ||||||
| use futures::StreamExt; | use futures::StreamExt; | ||||||
| use itertools::Itertools; | use itertools::Itertools; | ||||||
| use std::vec; | use std::vec; | ||||||
| @ -113,18 +111,6 @@ async fn test_general_airdrop() { | |||||||
|     assert_eq!(acc_bal_admin_3.balance, airdrop_amount * AIRDROP_MULTIPLE); |     assert_eq!(acc_bal_admin_3.balance, airdrop_amount * AIRDROP_MULTIPLE); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| #[tokio::test] |  | ||||||
| async fn test_vm_creation() { |  | ||||||
|     let db = prepare_test_db().await.unwrap(); |  | ||||||
| 
 |  | ||||||
|     let brain_channel = run_service_for_stream().await.unwrap(); |  | ||||||
|     let daemon_key = mock_vm_daemon(&brain_channel).await.unwrap(); |  | ||||||
| 
 |  | ||||||
|     let key = Key::new(); |  | ||||||
| 
 |  | ||||||
|     let _ = create_new_vm(&db, &key, &daemon_key, &brain_channel).await; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| #[tokio::test] | #[tokio::test] | ||||||
| async fn test_report_node() { | async fn test_report_node() { | ||||||
|     let db = prepare_test_db().await.unwrap(); |     let db = prepare_test_db().await.unwrap(); | ||||||
| @ -191,37 +177,3 @@ async fn test_list_operators() { | |||||||
| 
 | 
 | ||||||
|     assert!(!operators.is_empty()) |     assert!(!operators.is_empty()) | ||||||
| } | } | ||||||
| 
 |  | ||||||
| #[tokio::test] |  | ||||||
| // TODO: create vm for this user before testing this
 |  | ||||||
| async fn test_list_vm_contracts() { |  | ||||||
|     prepare_test_db().await.unwrap(); |  | ||||||
| 
 |  | ||||||
|     let channel = run_service_for_stream().await.unwrap(); |  | ||||||
|     let mut client = BrainVmCliClient::new(channel); |  | ||||||
| 
 |  | ||||||
|     let key = Key::new(); |  | ||||||
|     let pubkey = key.pubkey.clone(); |  | ||||||
| 
 |  | ||||||
|     let req_data = |  | ||||||
|         ListVmContractsReq { wallet: pubkey, uuid: String::from("uuid"), as_operator: false }; |  | ||||||
| 
 |  | ||||||
|     let mut grpc_stream = |  | ||||||
|         client.list_vm_contracts(key.sign_request(req_data).unwrap()).await.unwrap().into_inner(); |  | ||||||
| 
 |  | ||||||
|     let mut vm_contracts = Vec::new(); |  | ||||||
|     while let Some(stream_update) = grpc_stream.next().await { |  | ||||||
|         match stream_update { |  | ||||||
|             Ok(vm_c) => { |  | ||||||
|                 vm_contracts.push(vm_c); |  | ||||||
|             } |  | ||||||
|             Err(e) => { |  | ||||||
|                 panic!("Received error instead of vm_contracts: {e:?}"); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     assert!(vm_contracts.is_empty()) |  | ||||||
| 
 |  | ||||||
|     // verify report in db
 |  | ||||||
| } |  | ||||||
							
								
								
									
										90
									
								
								tests/grpc_vm_cli_test.rs
									
									
									
									
									
										Normal file
									
								
							
							
								
								
								
								
								
									
									
								
							
						
						
									
										90
									
								
								tests/grpc_vm_cli_test.rs
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,90 @@ | |||||||
|  | use common::prepare_test_env::{prepare_test_db, run_service_for_stream}; | ||||||
|  | use common::test_utils::Key; | ||||||
|  | use common::vm_cli_utils::create_new_vm; | ||||||
|  | use common::vm_daemon_utils::{mock_vm_daemon, register_vm_node}; | ||||||
|  | use detee_shared::vm_proto::brain_vm_cli_client::BrainVmCliClient; | ||||||
|  | use detee_shared::vm_proto::brain_vm_daemon_client::BrainVmDaemonClient; | ||||||
|  | use detee_shared::vm_proto::{ListVmContractsReq, NewVmReq}; | ||||||
|  | use futures::StreamExt; | ||||||
|  | use std::vec; | ||||||
|  | 
 | ||||||
|  | mod common; | ||||||
|  | 
 | ||||||
|  | #[tokio::test] | ||||||
|  | async fn test_vm_creation() { | ||||||
|  |     let db = prepare_test_db().await.unwrap(); | ||||||
|  |     // env_logger::builder().filter_level(log::LevelFilter::Error).init();
 | ||||||
|  | 
 | ||||||
|  |     let brain_channel = run_service_for_stream().await.unwrap(); | ||||||
|  |     let daemon_key = mock_vm_daemon(&brain_channel).await.unwrap(); | ||||||
|  | 
 | ||||||
|  |     let key = Key::new(); | ||||||
|  | 
 | ||||||
|  |     let _ = create_new_vm(&db, &key, &daemon_key, &brain_channel).await; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #[tokio::test] | ||||||
|  | async fn test_vm_creation_timeout() { | ||||||
|  |     prepare_test_db().await.unwrap(); | ||||||
|  |     // env_logger::builder().filter_level(log::LevelFilter::Error).init();
 | ||||||
|  | 
 | ||||||
|  |     let brain_channel = run_service_for_stream().await.unwrap(); | ||||||
|  |     let mut daemon_client = BrainVmDaemonClient::new(brain_channel.clone()); | ||||||
|  |     let daemon_key = Key::new(); | ||||||
|  | 
 | ||||||
|  |     register_vm_node(&mut daemon_client, &daemon_key, &Key::new().pubkey).await.unwrap(); | ||||||
|  | 
 | ||||||
|  |     let key = Key::new(); | ||||||
|  | 
 | ||||||
|  |     let new_vm_req = NewVmReq { | ||||||
|  |         admin_pubkey: key.pubkey.clone(), | ||||||
|  |         node_pubkey: daemon_key.pubkey, | ||||||
|  |         price_per_unit: 1200, | ||||||
|  |         extra_ports: vec![8080, 8081], | ||||||
|  |         locked_nano: 0, | ||||||
|  |         ..Default::default() | ||||||
|  |     }; | ||||||
|  | 
 | ||||||
|  |     let mut client_vm_cli = BrainVmCliClient::new(brain_channel.clone()); | ||||||
|  |     let timeout_error = | ||||||
|  |         client_vm_cli.new_vm(key.sign_request(new_vm_req).unwrap()).await.err().unwrap(); | ||||||
|  | 
 | ||||||
|  |     assert_eq!( | ||||||
|  |         timeout_error.message(), | ||||||
|  |         "Request failed due to timeout. Please try again later or contact the DeTEE devs team." | ||||||
|  |     ) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #[tokio::test] | ||||||
|  | // TODO: create vm for this user before testing this
 | ||||||
|  | async fn test_list_vm_contracts() { | ||||||
|  |     prepare_test_db().await.unwrap(); | ||||||
|  | 
 | ||||||
|  |     let channel = run_service_for_stream().await.unwrap(); | ||||||
|  |     let mut client = BrainVmCliClient::new(channel); | ||||||
|  | 
 | ||||||
|  |     let key = Key::new(); | ||||||
|  |     let pubkey = key.pubkey.clone(); | ||||||
|  | 
 | ||||||
|  |     let req_data = | ||||||
|  |         ListVmContractsReq { wallet: pubkey, uuid: String::from("uuid"), as_operator: false }; | ||||||
|  | 
 | ||||||
|  |     let mut grpc_stream = | ||||||
|  |         client.list_vm_contracts(key.sign_request(req_data).unwrap()).await.unwrap().into_inner(); | ||||||
|  | 
 | ||||||
|  |     let mut vm_contracts = Vec::new(); | ||||||
|  |     while let Some(stream_update) = grpc_stream.next().await { | ||||||
|  |         match stream_update { | ||||||
|  |             Ok(vm_c) => { | ||||||
|  |                 vm_contracts.push(vm_c); | ||||||
|  |             } | ||||||
|  |             Err(e) => { | ||||||
|  |                 panic!("Received error instead of vm_contracts: {e:?}"); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     assert!(vm_contracts.is_empty()) | ||||||
|  | 
 | ||||||
|  |     // verify report in db
 | ||||||
|  | } | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user