diff --git a/qds_sdk/engine.py b/qds_sdk/engine.py index 3070f699..ee55e50d 100644 --- a/qds_sdk/engine.py +++ b/qds_sdk/engine.py @@ -147,7 +147,7 @@ def engine_parser(argparser): engine_group = argparser.add_argument_group("engine settings") engine_group.add_argument("--flavour", dest="flavour", - choices=["hadoop", "hadoop2", "presto", "spark", "hbase", "airflow", "deeplearning"], + choices=["hadoop", "hadoop2", "presto", "spark", "sparkstreaming", "hbase", "airflow", "deeplearning"], default=None, help="Set engine flavour") diff --git a/tests/test_clusterv2.py b/tests/test_clusterv2.py index 4861a2fa..34dd8433 100644 --- a/tests/test_clusterv2.py +++ b/tests/test_clusterv2.py @@ -460,6 +460,23 @@ def test_spark_engine_config(self): 'custom_spark_config': 'spark-overrides'}}, 'cluster_info': {'label': ['test_label'],}}) + def test_sparkstreaming_engine_config(self): + with tempfile.NamedTemporaryFile() as temp: + temp.write("config.properties:\na=1\nb=2".encode("utf8")) + temp.flush() + sys.argv = ['qds.py', '--version', 'v2', 'cluster', 'create', '--label', 'test_label', + '--flavour', 'sparkstreaming', '--custom-spark-config', 'spark-overrides'] + Qubole.cloud = None + print_command() + Connection._api_call = Mock(return_value={}) + qds.main() + Connection._api_call.assert_called_with('POST', 'clusters', + {'engine_config': + {'flavour': 'sparkstreaming', + 'spark_settings': { + 'custom_spark_config': 'spark-overrides'}}, + 'cluster_info': {'label': ['test_label'],}}) + def test_airflow_engine_config(self): with tempfile.NamedTemporaryFile() as temp: temp.write("config.properties:\na=1\nb=2".encode("utf8")) @@ -787,7 +804,7 @@ def test_engine_config(self): temp.write("a=1\nb=2".encode("utf8")) temp.flush() sys.argv = ['qds.py', '--version', 'v2', 'cluster', 'update', '123', - '--use-qubole-placement-policy', '--enable-rubix', + '--use-qubole-placement-policy', '--enable-rubix', '--custom-hadoop-config',temp.name] Qubole.cloud = None print_command()