Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: sync internal changes to open source #6

Merged
merged 1 commit into from
Feb 26, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
9 changes: 5 additions & 4 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

7 changes: 4 additions & 3 deletions rust/cli/Cargo.toml
Original file line number Diff line number Diff line change
@@ -1,12 +1,13 @@
[package]
name = "quary"
version = "0.0.87"
version = "0.0.91"
edition = "2021"
rust-version = "1.75.0"
rust-version = "1.76.0"

# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html

[dependencies]
yup-oauth2 = { version = "8", default-features = false }
clap = { version = "4", features = ["derive"] }
quary-core = { path = "../core" }
dbt-converter = { path = "../dbt-converter" }
Expand All @@ -17,7 +18,7 @@ async-trait = "0.1"
indicatif = "0.17"
gcp-bigquery-client = "0.18"
prost = "0.12"
google-cloud-auth = { version = "0.13", default-features = false, features = [ "external-account", "rustls-tls"] }
google-cloud-auth = { version = "0.13", default-features = false, features = ["external-account", "rustls-tls"] }
snowflake-api = "0.6"
arrow-array = "50"
duckdb = { version = "0.10", features = ["bundled"] }
Expand Down
65 changes: 36 additions & 29 deletions rust/cli/src/databases_bigquery.rs
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ use quary_core::databases::{
};
use std::fmt::Debug;
use std::sync::Arc;
use yup_oauth2::error::AuthErrorCode;

pub struct BigQuery {
project_id: String,
Expand Down Expand Up @@ -61,7 +62,13 @@ impl Authenticator for AccessTokenProviderHolder {
impl Authenticator for AccessTokenProvider {
async fn access_token(&self) -> Result<String, BQError> {
let token_source = &self.token_source;
let token = token_source.token().await.unwrap();
let token = token_source.token().await.map_err(|_| {
BQError::AuthError(yup_oauth2::error::AuthError {
error: AuthErrorCode::ExpiredToken,
error_description: None,
error_uri: None,
})
})?;
Ok(token.access_token)
}
}
Expand Down Expand Up @@ -131,7 +138,7 @@ impl BigQuery {
.list(&self.project_id, &self.dataset_id, options)
.await
.map_err(|e| format!("Failed to list tables: {}", e))?;
collected_tables.extend(tables.tables.unwrap());
collected_tables.extend(tables.tables.unwrap_or_default());
if tables.next_page_token.is_none() {
break;
}
Expand All @@ -145,8 +152,8 @@ impl BigQuery {
impl DatabaseConnection for BigQuery {
// TODO Return an iterator
async fn list_tables(&self) -> Result<Vec<TableAddress>, String> {
let collected_tables = self.get_all_table_like_things().await?;
let tables = collected_tables
self.get_all_table_like_things()
.await?
.iter()
.filter(|table| {
if let Some(kind) = &table.kind {
Expand All @@ -155,23 +162,21 @@ impl DatabaseConnection for BigQuery {
false
}
})
.map(|t| TableAddress {
full_path: format!(
"{}.{}.{}",
self.project_id,
self.dataset_id,
t.friendly_name.clone().unwrap()
),
name: t.friendly_name.clone().unwrap(),
.map(|t| {
let name = t
.friendly_name
.clone()
.ok_or("Failed to get friendly name of table".to_string())?;
Ok(TableAddress {
full_path: format!("{}.{}.{}", self.project_id, self.dataset_id, name),
name,
})
})
.collect();

Ok(tables)
.collect()
}

async fn list_views(&self) -> Result<Vec<TableAddress>, String> {
let collected_tables = self.get_all_table_like_things().await?;
let tables = collected_tables
self.get_all_table_like_things().await?
.iter()
.filter(|table| {
if let Some(kind) = &table.kind {
Expand All @@ -180,18 +185,20 @@ impl DatabaseConnection for BigQuery {
false
}
})
.map(|t| TableAddress {
full_path: format!(
"{}.{}.{}",
self.project_id,
self.dataset_id,
t.friendly_name.clone().unwrap()
),
name: t.friendly_name.clone().unwrap(),
.map(|t| {
let friendly_name = t
.friendly_name
.clone()
.ok_or("Failed to get friendly name of table".to_string())?;
Ok(TableAddress {
full_path: format!(
"{}.{}.{}",
self.project_id, self.dataset_id, friendly_name,
),
name: friendly_name,
})
})
.collect();

Ok(tables)
.collect()
}

async fn list_columns(&self, table: &str) -> Result<Vec<String>, String> {
Expand All @@ -206,7 +213,7 @@ impl DatabaseConnection for BigQuery {
)
.await
.map_err(|e| format!("Failed to get table {}: {}", table, e))?;
let fields = tables.schema.fields.unwrap();
let fields = tables.schema.fields.unwrap_or_default();
let columns = fields.iter().map(|f| f.name.clone()).collect();
Ok(columns)
}
Expand Down
12 changes: 9 additions & 3 deletions rust/cli/src/databases_duckdb.rs
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,7 @@
"SELECT table_name FROM information_schema.tables WHERE table_schema = '{}' AND type='table' ORDER BY name",
schema
))
.await?
.await?
} else {
self.query("SELECT name FROM sqlite_master WHERE type='table' ORDER BY name")
.await?
Expand Down Expand Up @@ -111,14 +111,20 @@
}

async fn exec(&self, query: &str) -> Result<(), String> {
let conn = self.connection.lock().unwrap();
let conn = self
.connection
.lock()
.map_err(|e| format!("Failed to get connection lock: {}", e))?;
conn.execute(query, params![])
.map_err(|e| format!("Failed to execute query {}: {}", query, e))?;
return Ok(());
}

async fn query(&self, query: &str) -> Result<QueryResult, String> {
let conn = self.connection.lock().unwrap();
let conn = self
.connection
.lock()
.map_err(|e| format!("Failed to get connection lock: {}", e))?;

let mut stmt = conn
.prepare(query)
Expand Down Expand Up @@ -164,7 +170,7 @@
rows.push(row);
}

for i in 0..num_rows {

Check warning on line 173 in rust/cli/src/databases_duckdb.rs

View workflow job for this annotation

GitHub Actions / Rust Lint

the loop variable `i` is used to index `rows`
for j in 0..array.len() {
let array = &array[j];
if let Some(string_array) = array.as_any().downcast_ref::<array::StringArray>() {
Expand Down
16 changes: 14 additions & 2 deletions rust/cli/src/main.rs
Original file line number Diff line number Diff line change
@@ -1,3 +1,11 @@
#![deny(clippy::expect_used)]
#![deny(clippy::needless_lifetimes)]
#![deny(clippy::needless_borrow)]
#![deny(clippy::useless_conversion)]
#![deny(clippy::unwrap_used)]
#![deny(unused_imports)]
#![deny(unused_import_braces)]

use crate::commands::{mode_to_test_runner, Cli, Commands, InitType};
use crate::databases_connection::{database_from_config, database_query_generator_from_config};
use clap::Parser;
Expand Down Expand Up @@ -48,7 +56,9 @@
for file in Asset::iter() {
let filename = file.as_ref();
let path = Path::new(filename);
let prefix = path.parent().expect("no parent");
let prefix = path
.parent()
.ok_or("Could not get parent directory for file in Asset::iter()")?;
if !prefix.exists() {
fs::create_dir_all(prefix).map_err(|e| e.to_string())?;
}
Expand All @@ -65,7 +75,9 @@
for file in DuckDBAsset::iter() {
let filename = file.as_ref();
let path = Path::new(filename);
let prefix = path.parent().expect("no parent");
let prefix = path.parent().ok_or(
"Could not get parent directory for file in DuckDBAsset::iter()",
)?;
if !prefix.exists() {
fs::create_dir_all(prefix).map_err(|e| e.to_string())?;
}
Expand Down Expand Up @@ -251,7 +263,7 @@
.map_err(|e| format!("reading database from config: {:?}", e))?;
println!("{:?}", database);

let database = Arc::new(database);

Check warning on line 266 in rust/cli/src/main.rs

View workflow job for this annotation

GitHub Actions / Rust Lint

usage of an `Arc` that is not `Send` and `Sync`
let func: RunStatementFunc = Box::new(move |sql: &str| {
let database = Arc::clone(&database);
let sql = sql.to_owned();
Expand Down
4 changes: 2 additions & 2 deletions rust/core/Cargo.toml
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
[package]
name = "quary-core"
version = "0.1.0"
version = "0.0.91"
authors = ["Ben King <[email protected]>"]
edition = "2021"
rust-version = "1.75.0"
rust-version = "1.76.0"

[lib]
crate-type = ["cdylib", "rlib"]
Expand Down
32 changes: 32 additions & 0 deletions rust/core/src/automatic_branching.rs
Original file line number Diff line number Diff line change
Expand Up @@ -955,4 +955,36 @@ sources:
let result = cache_view_name_to_table_name_and_hash(cache_view_name);
assert!(result.is_err());
}

#[test]
fn test_derive_hash_views_on_seed() {
let fs = quary_proto::FileSystem {
files: HashMap::from([
(
"seeds/seed_checkout_disputes.csv".to_string(),
File {
name: "seeds/seed_checkout_disputes.csv".to_string(),
contents: prost::bytes::Bytes::from("id,order_id,payment_method,amount"),
},
),
(
"quary.yaml".to_string(),
File {
name: "quary.yaml".to_string(),
contents: prost::bytes::Bytes::from(
r#"
sqliteInMemory: {}
"#
.as_bytes(),
),
},
),
]),
};
let database = DatabaseQueryGeneratorSqlite {};
let project = parse_project(&fs, &database, "").unwrap();
let graph = project_to_graph(project.clone()).unwrap();

assert!(derive_hash_views(&database, &project, &graph).is_ok());
}
}
Loading
Loading