mirror of
https://github.com/enso-org/enso.git
synced 2024-12-18 19:41:32 +03:00
6b8d8e9270
[Task link](https://www.pivotaltracker.com/story/show/184012434) This PR implements Intermediate Representation for our documentation. Later these data structures would be used to generate HTML and CSS for the documentation panel. For now, we display it in the debug scene. https://user-images.githubusercontent.com/6566674/210674850-480a3e6e-76c3-4f34-a235-15c44dc9ec01.mp4 # Important Notes - `suggestion-database` now lives in a separate crate - also, two utility crates were introduced for the `notification` and `executor` modules of enso-gui - documentation debug scene is moved to a separate crate - All refactorings are done in the last two commits
60 lines
2.6 KiB
Rust
60 lines
2.6 KiB
Rust
//! Project Manager tests.
|
|
|
|
// === Non-Standard Linter Configuration ===
|
|
#![deny(non_ascii_idents)]
|
|
#![warn(unsafe_code)]
|
|
|
|
|
|
|
|
#[cfg(test)]
|
|
mod tests {
|
|
use enso_gui::prelude::*;
|
|
|
|
use engine_protocol::project_manager::Client;
|
|
use engine_protocol::project_manager::API;
|
|
use enso_gui::transport::web::WebSocket;
|
|
|
|
use engine_protocol::project_manager::MissingComponentAction::Install;
|
|
use engine_protocol::project_manager::ProjectName;
|
|
use wasm_bindgen_test::wasm_bindgen_test_configure;
|
|
|
|
wasm_bindgen_test_configure!(run_in_browser);
|
|
|
|
|
|
//#[wasm_bindgen_test::wasm_bindgen_test(async)]
|
|
#[allow(dead_code)]
|
|
async fn project_life_cycle() {
|
|
let logger = Logger::new("test");
|
|
let ws = WebSocket::new_opened(logger, "ws://localhost:30535").await;
|
|
let ws = ws.expect("Couldn't connect to WebSocket server.");
|
|
let client = Client::new(ws);
|
|
let _executor = enso_executor::setup_global_executor();
|
|
|
|
executor::global::spawn(client.runner());
|
|
|
|
let name = ProjectName::new_unchecked("TestProject");
|
|
let creation = client.create_project(&name, &None, &None, &Install);
|
|
let created = creation.await.expect("Couldn't create project.");
|
|
let uuid = created.project_id;
|
|
let _address = client.open_project(&uuid, &Install).await.expect("Couldn't open project.");
|
|
client.close_project(&uuid).await.expect("Couldn't close project.");
|
|
let list_response = client.list_projects(&None).await;
|
|
let list_response = list_response.expect("Couldn't list recent projects.");
|
|
assert!(list_response.projects.iter().any(|project| project.name == name));
|
|
|
|
let new_name = ProjectName::new_unchecked("NewTestProject");
|
|
client.rename_project(&uuid, &new_name).await.expect("Couldn't rename project.");
|
|
let list_response = client.list_projects(&None).await;
|
|
let list_response = list_response.expect("Couldn't list recent projects.");
|
|
assert!(!list_response.projects.iter().any(|project| project.name == name));
|
|
assert!(list_response.projects.iter().any(|project| project.name == new_name));
|
|
|
|
client.delete_project(&uuid).await.expect("Couldn't delete project.");
|
|
let list_response = client.list_projects(&None).await;
|
|
let list_response = list_response.expect("Couldn't list recent projects.");
|
|
assert!(!list_response.projects.iter().any(|project| project.name == name));
|
|
// FIXME[dg]: project/listSample isn't implemented on the server-side yet.
|
|
//client.list_samples(10).await.expect("Couldn't list samples.");
|
|
}
|
|
}
|