Skip to content
This repository has been archived by the owner on Oct 25, 2024. It is now read-only.

Commit

Permalink
fuel-indexer: refactor run, service, and executor
Browse files Browse the repository at this point in the history
  • Loading branch information
lostman committed Sep 4, 2023
1 parent 254fe98 commit 80074af
Show file tree
Hide file tree
Showing 6 changed files with 217 additions and 314 deletions.
7 changes: 2 additions & 5 deletions packages/fuel-indexer-benchmarks/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ use fuel_indexer::{
use fuel_indexer_database::IndexerConnectionPool;
use fuel_indexer_lib::config::DatabaseConfig;
use fuel_indexer_tests::fixtures::TestPostgresDb;
use std::{str::FromStr, sync::atomic::AtomicBool};
use std::str::FromStr;

/// Location of Fuel node to be used for block retrieval.
pub const NODE_URL: &str = "beta-4.fuel.network:80";
Expand Down Expand Up @@ -73,7 +73,6 @@ pub fn create_wasm_indexer_benchmark(
.unwrap();
let blocks = rt.block_on(get_blocks(start_block, num_blocks)).unwrap();
c.bench_function(name, move |b| {
let kill_switch = std::sync::Arc::new(AtomicBool::new(false));
b.iter_batched(
// This setup function is run prior to each iteration of
// the benchmark; this ensures that there is a fresh WASM
Expand All @@ -92,9 +91,7 @@ pub fn create_wasm_indexer_benchmark(
(executor, blocks.clone())
})
},
|(mut ex, blocks)| {
rt.block_on(ex.handle_events(kill_switch.clone(), blocks))
},
|(mut ex, blocks)| rt.block_on(ex.handle_events(blocks)),
criterion::BatchSize::SmallInput,
)
});
Expand Down
92 changes: 32 additions & 60 deletions packages/fuel-indexer-tests/tests/graphql_server.rs
Original file line number Diff line number Diff line change
@@ -1,24 +1,18 @@
use fuel_indexer_tests::fixtures::{
mock_request, setup_web_test_components, WebTestComponents,
};
use fuel_indexer_tests::fixtures::{mock_request, setup_web_test_components};
use fuel_indexer_utils::uid;
use hyper::header::CONTENT_TYPE;
use serde_json::{Number, Value};
use std::collections::HashMap;

#[actix_web::test]
async fn test_entity_with_required_and_optional_fields() {
let WebTestComponents {
server,
db: _db,
client,
..
} = setup_web_test_components(None).await;
let test = setup_web_test_components(None).await;

mock_request("/block").await;

// All required
let resp = client
let resp = test
.client
.post("http://127.0.0.1:29987/api/graph/fuel_indexer_test/index1")
.header(CONTENT_TYPE, "application/graphql".to_owned())
.body(r#"{ "query": "query { blockentity { id height timestamp }}" }"#)
Expand All @@ -37,7 +31,7 @@ async fn test_entity_with_required_and_optional_fields() {
assert!(data[1]["timestamp"].as_u64().unwrap() > 0);

// Optionals
let resp = client
let resp = test.client
.post("http://127.0.0.1:29987/api/graph/fuel_indexer_test/index1")
.header(CONTENT_TYPE, "application/graphql".to_owned())
.body(r#"{ "query": "query { optionentity { int_required int_optional_some addr_optional_none }}"}"#)
Expand All @@ -53,22 +47,18 @@ async fn test_entity_with_required_and_optional_fields() {
assert_eq!(data[0]["int_optional_some"], Value::from(Number::from(999)));
assert_eq!(data[0]["addr_optional_none"], Value::from(None::<&str>));

server.abort();
test.server.abort();
}

#[actix_web::test]
async fn test_entity_with_foreign_keys() {
let WebTestComponents {
server,
db: _db,
client,
..
} = setup_web_test_components(None).await;
let test = setup_web_test_components(None).await;

mock_request("/block").await;

// Implicit foreign keys
let resp = client
let resp = test
.client
.post("http://127.0.0.1:29987/api/graph/fuel_indexer_test/index1")
.header(CONTENT_TYPE, "application/graphql".to_owned())
.body(r#"{ "query": "query { txentity { block { id height } id timestamp } }" }"#)
Expand All @@ -86,7 +76,8 @@ async fn test_entity_with_foreign_keys() {
assert!(data[0]["block"]["height"].as_i64().unwrap() > 0);

// Explicit foreign keys
let resp = client
let resp = test
.client
.post("http://127.0.0.1:29987/api/graph/fuel_indexer_test/index1")
.header(CONTENT_TYPE, "application/graphql".to_owned())
.body(
Expand All @@ -110,17 +101,12 @@ async fn test_entity_with_foreign_keys() {
Some("Republic of Indexia")
);

server.abort();
test.server.abort();
}

#[actix_web::test]
async fn test_deeply_nested_entity() {
let WebTestComponents {
server,
db: _db,
client,
..
} = setup_web_test_components(None).await;
let test = setup_web_test_components(None).await;

mock_request("/deeply_nested").await;

Expand Down Expand Up @@ -185,7 +171,8 @@ async fn test_deeply_nested_entity() {
}",
)]);

let resp = client
let resp = test
.client
.post("http://127.0.0.1:29987/api/graph/fuel_indexer_test/index1")
.header(CONTENT_TYPE, "application/graphql".to_owned())
.json(&deeply_nested_query)
Expand Down Expand Up @@ -245,25 +232,20 @@ async fn test_deeply_nested_entity() {
Some("Ava")
);

server.abort();
test.server.abort();
}

#[actix_web::test]
async fn test_filtering() {
let WebTestComponents {
server,
db: _db,
client,
..
} = setup_web_test_components(None).await;
let test = setup_web_test_components(None).await;

mock_request("/ping").await;

// "4bf5122f344554c53bde2ebb8cd2b7e3d1600ad631c385a5d7cce23c7785459a"
let _id = uid([1]).to_string();

// ID selection
let resp = client
let resp = test.client
.post("http://127.0.0.1:29987/api/graph/fuel_indexer_test/index1")
.header(CONTENT_TYPE, "application/graphql".to_owned())
.body(r#"{ "query": "query { filterentity(id: \"4bf5122f344554c53bde2ebb8cd2b7e3d1600ad631c385a5d7cce23c7785459a\") { id foola maybe_null_bar bazoo } }" }"#)
Expand All @@ -284,7 +266,7 @@ async fn test_filtering() {
assert_eq!(data[0]["bazoo"].as_i64(), Some(1));

// Set membership
let resp = client
let resp = test.client
.post("http://127.0.0.1:29987/api/graph/fuel_indexer_test/index1")
.header(CONTENT_TYPE, "application/graphql".to_owned())
.body(
Expand All @@ -308,7 +290,7 @@ async fn test_filtering() {
assert_eq!(data[1]["bazoo"].as_i64(), Some(5));

// Non-null
let resp = client
let resp = test.client
.post("http://127.0.0.1:29987/api/graph/fuel_indexer_test/index1")
.header(CONTENT_TYPE, "application/graphql".to_owned())
.body(
Expand All @@ -332,7 +314,7 @@ async fn test_filtering() {
assert_eq!(data[1]["bazoo"].as_i64(), Some(1000));

// Complex comparison
let resp = client
let resp = test.client
.post("http://127.0.0.1:29987/api/graph/fuel_indexer_test/index1")
.header(CONTENT_TYPE, "application/graphql".to_owned())
.body(
Expand All @@ -356,7 +338,7 @@ async fn test_filtering() {
assert_eq!(data[1]["bazoo"].as_i64(), Some(5));

// Simple comparison
let resp = client
let resp = test.client
.post("http://127.0.0.1:29987/api/graph/fuel_indexer_test/index1")
.header(CONTENT_TYPE, "application/graphql".to_owned())
.body(r#"{ "query": "query { filterentity(filter: { bazoo: { lt: 1000 } } ) { id foola maybe_null_bar bazoo } }" }"#)
Expand All @@ -378,7 +360,7 @@ async fn test_filtering() {
assert_eq!(data[1]["bazoo"].as_i64(), Some(5));

// Nested filters
let resp = client
let resp = test.client
.post("http://127.0.0.1:29987/api/graph/fuel_indexer_test/index1")
.header(CONTENT_TYPE, "application/graphql".to_owned())
.body(
Expand All @@ -402,7 +384,7 @@ async fn test_filtering() {
assert_eq!(data[0]["inner_entity"]["inner_baz"].as_u64(), Some(600));

// Multiple filters on single entity
let resp = client
let resp = test.client
.post("http://127.0.0.1:29987/api/graph/fuel_indexer_test/index1")
.header(CONTENT_TYPE, "application/graphql".to_owned())
.body(
Expand All @@ -422,7 +404,7 @@ async fn test_filtering() {
assert_eq!(data[0]["bazoo"].as_i64(), Some(1));

// Negation
let resp = client
let resp = test.client
.post("http://127.0.0.1:29987/api/graph/fuel_indexer_test/index1")
.header(CONTENT_TYPE, "application/graphql".to_owned())
.body(
Expand All @@ -441,21 +423,16 @@ async fn test_filtering() {
assert_eq!(data[0]["maybe_null_bar"].as_i64(), Some(456));
assert_eq!(data[0]["bazoo"].as_i64(), Some(1000));

server.abort();
test.server.abort();
}

#[actix_web::test]
async fn test_sorting() {
let WebTestComponents {
server,
db: _db,
client,
..
} = setup_web_test_components(None).await;
let test = setup_web_test_components(None).await;

mock_request("/ping").await;

let resp = client
let resp = test.client
.post("http://127.0.0.1:29987/api/graph/fuel_indexer_test/index1")
.header(CONTENT_TYPE, "application/graphql".to_owned())
.body(
Expand All @@ -476,21 +453,16 @@ async fn test_sorting() {
assert_eq!(data[2]["id"].as_str().unwrap(), uid([1]).to_string());
assert_eq!(data[2]["foola"].as_str(), Some("beep"));

server.abort();
test.server.abort();
}

#[actix_web::test]
async fn test_aliasing_and_pagination() {
let WebTestComponents {
server,
db: _db,
client,
..
} = setup_web_test_components(None).await;
let test = setup_web_test_components(None).await;

mock_request("/ping").await;

let resp = client
let resp = test.client
.post("http://127.0.0.1:29987/api/graph/fuel_indexer_test/index1")
.header(CONTENT_TYPE, "application/graphql".to_owned())
.body(
Expand All @@ -510,5 +482,5 @@ async fn test_aliasing_and_pagination() {
);
assert_eq!(data[0]["page_info"]["pages"].as_i64(), Some(3));

server.abort();
test.server.abort();
}
5 changes: 1 addition & 4 deletions packages/fuel-indexer-tests/tests/service.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,6 @@ use fuel_indexer::{Executor, IndexerConfig, WasmIndexExecutor};
use fuel_indexer_lib::{config::DatabaseConfig, manifest::Manifest};
use fuel_indexer_tests::fixtures::TestPostgresDb;
use std::str::FromStr;
use std::sync::atomic::AtomicBool;

#[tokio::test]
async fn test_wasm_executor_can_meter_execution() {
Expand Down Expand Up @@ -58,11 +57,9 @@ async fn test_wasm_executor_can_meter_execution() {
.await
.unwrap();

let kill_switch = std::sync::Arc::new(AtomicBool::new(false));

let blocks: Vec<fuel_indexer_types::fuel::BlockData> = vec![];

if let Err(e) = executor.handle_events(kill_switch, blocks.clone()).await {
if let Err(e) = executor.handle_events(blocks.clone()).await {
if let fuel_indexer::IndexerError::RuntimeError(e) = e {
if let Some(e) = e.to_trap() {
assert_eq!(e, wasmer_types::TrapCode::UnreachableCodeReached);
Expand Down
7 changes: 6 additions & 1 deletion packages/fuel-indexer/src/commands/run.rs
Original file line number Diff line number Diff line change
Expand Up @@ -130,7 +130,12 @@ pub async fn exec(args: IndexerArgs) -> anyhow::Result<()> {
}
}

subsystems.spawn(service.run());
subsystems.spawn(async {
let result = service.run().await;
if let Err(e) = result {
tracing::error!("Indexer Service failed: {e}");
}
});

#[cfg(feature = "api-server")]
subsystems.spawn({
Expand Down
Loading

0 comments on commit 80074af

Please sign in to comment.