Skip to content

Commit

Permalink
feat: default export catalog name
Browse files Browse the repository at this point in the history
  • Loading branch information
fengjiachun committed Jul 30, 2024
1 parent 6d8a502 commit 88794b4
Show file tree
Hide file tree
Showing 2 changed files with 24 additions and 17 deletions.
31 changes: 23 additions & 8 deletions src/cmd/src/cli/export.rs
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ use common_telemetry::{debug, error, info, warn};
use serde_json::Value;
use servers::http::greptime_result_v1::GreptimedbV1Response;
use servers::http::GreptimeQueryOutput;
use snafu::{OptionExt, ResultExt};
use snafu::ResultExt;
use tokio::fs::File;
use tokio::io::{AsyncWriteExt, BufWriter};
use tokio::sync::Semaphore;
Expand All @@ -34,8 +34,7 @@ use tracing_appender::non_blocking::WorkerGuard;

use crate::cli::{Instance, Tool};
use crate::error::{
EmptyResultSnafu, Error, FileIoSnafu, HttpQuerySqlSnafu, InvalidDatabaseNameSnafu, Result,
SerdeJsonSnafu,
EmptyResultSnafu, Error, FileIoSnafu, HttpQuerySqlSnafu, Result, SerdeJsonSnafu,
};

type TableReference = (String, String, String);
Expand Down Expand Up @@ -539,11 +538,11 @@ impl Tool for Export {

/// Split at `-`.
fn split_database(database: &str) -> Result<(String, Option<String>)> {
let (catalog, schema) = database
.split_once('-')
.with_context(|| InvalidDatabaseNameSnafu {
database: database.to_string(),
})?;
let (catalog, schema) = match database.split_once('-') {
Some((catalog, schema)) => (catalog, schema),
None => ("greptime", database),
};

if schema == "*" {
Ok((catalog.to_string(), None))
} else {
Expand All @@ -558,10 +557,26 @@ mod tests {
use common_catalog::consts::{DEFAULT_CATALOG_NAME, DEFAULT_SCHEMA_NAME};
use common_telemetry::logging::LoggingOptions;

use crate::cli::export::split_database;
use crate::error::Result as CmdResult;
use crate::options::GlobalOptions;
use crate::{cli, standalone, App};

#[test]
fn test_split_database() {
let result = split_database("catalog-schema").unwrap();
assert_eq!(result, ("catalog".to_string(), Some("schema".to_string())));

let result = split_database("schema").unwrap();
assert_eq!(result, ("greptime".to_string(), Some("schema".to_string())));

let result = split_database("catalog-*").unwrap();
assert_eq!(result, ("catalog".to_string(), None));

let result = split_database("*").unwrap();
assert_eq!(result, ("greptime".to_string(), None));
}

#[tokio::test(flavor = "multi_thread")]
async fn test_export_create_table_with_quoted_names() -> CmdResult<()> {
let output_dir = tempfile::tempdir().unwrap();
Expand Down
10 changes: 1 addition & 9 deletions src/cmd/src/error.rs
Original file line number Diff line number Diff line change
Expand Up @@ -298,13 +298,6 @@ pub enum Error {
error: std::io::Error,
},

#[snafu(display("Invalid database name: {}", database))]
InvalidDatabaseName {
#[snafu(implicit)]
location: Location,
database: String,
},

#[snafu(display("Failed to create directory {}", dir))]
CreateDir {
dir: String,
Expand Down Expand Up @@ -384,8 +377,7 @@ impl ErrorExt for Error {
| Error::ConnectEtcd { .. }
| Error::NotDataFromOutput { .. }
| Error::CreateDir { .. }
| Error::EmptyResult { .. }
| Error::InvalidDatabaseName { .. } => StatusCode::InvalidArguments,
| Error::EmptyResult { .. } => StatusCode::InvalidArguments,

Error::StartProcedureManager { source, .. }
| Error::StopProcedureManager { source, .. } => source.status_code(),
Expand Down

0 comments on commit 88794b4

Please sign in to comment.