-
Notifications
You must be signed in to change notification settings - Fork 85
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
E2E GCS Sink additional test scenarios. #1478
base: develop
Are you sure you want to change the base?
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,73 @@ | ||
@GCS_Sink | ||
Feature: GCS sink - Verification of GCS Sink plugin macro scenarios | ||
|
||
@CMEK @BQ_SOURCE_TEST @GCS_SINK_TEST | ||
Scenario:Validate successful records transfer from BigQuery to GCS with macro enabled at sink | ||
Given Open Datafusion Project to configure pipeline | ||
Then Select plugin: "BigQuery" from the plugins list as: "Source" | ||
When Expand Plugin group in the LHS plugins list: "Sink" | ||
When Select plugin: "GCS" from the plugins list as: "Sink" | ||
Then Connect source as "BigQuery" and sink as "GCS" to establish connection | ||
Then Open BigQuery source properties | ||
Then Override Service account details if set in environment variables | ||
Then Enter the BigQuery source mandatory properties | ||
Then Validate "BigQuery" plugin properties | ||
Then Close the BigQuery properties | ||
Then Open GCS sink properties | ||
Then Enter GCS property reference name | ||
Then Enter GCS property "projectId" as macro argument "gcsProjectId" | ||
Then Enter GCS property "serviceAccountType" as macro argument "serviceAccountType" | ||
Then Enter GCS property "serviceAccountFilePath" as macro argument "serviceAccount" | ||
Then Enter GCS property "serviceAccountJSON" as macro argument "serviceAccount" | ||
Then Enter GCS property "path" as macro argument "gcsSinkPath" | ||
Then Enter GCS sink property "pathSuffix" as macro argument "gcsPathSuffix" | ||
Then Enter GCS property "format" as macro argument "gcsFormat" | ||
Then Click on the Macro button of Property: "writeHeader" and set the value to: "WriteHeader" | ||
Then Click on the Macro button of Property: "location" and set the value to: "gcsSinkLocation" | ||
Then Click on the Macro button of Property: "contentType" and set the value to: "gcsContentType" | ||
Then Click on the Macro button of Property: "outputFileNameBase" and set the value to: "OutFileNameBase" | ||
Then Click on the Macro button of Property: "fileSystemProperties" and set the value to: "FileSystemPr" | ||
Then Enter GCS sink cmek property "encryptionKeyName" as macro argument "cmekGCS" if cmek is enabled | ||
Then Validate "GCS" plugin properties | ||
Then Close the GCS properties | ||
Then Save the pipeline | ||
Then Preview and run the pipeline | ||
Then Enter runtime argument value "projectId" for key "gcsProjectId" | ||
Then Enter runtime argument value "serviceAccountType" for key "serviceAccountType" | ||
Then Enter runtime argument value "serviceAccount" for key "serviceAccount" | ||
Then Enter runtime argument value for GCS sink property path key "gcsSinkPath" | ||
Then Enter runtime argument value "gcsPathDateSuffix" for key "gcsPathSuffix" | ||
Then Enter runtime argument value "csvFormat" for key "gcsFormat" | ||
Then Enter runtime argument value "writeHeader" for key "WriteHeader" | ||
Then Enter runtime argument value "contentType" for key "gcsContentType" | ||
Then Enter runtime argument value "gcsSinkBucketLocation" for key "gcsSinkLocation" | ||
Then Enter runtime argument value "outputFileNameBase" for key "OutFileNameBase" | ||
Then Enter runtime argument value "gcsFileSysProperty" for key "FileSystemPr" | ||
Then Enter runtime argument value "cmekGCS" for GCS cmek property key "cmekGCS" if GCS cmek is enabled | ||
Then Run the preview of pipeline with runtime arguments | ||
Then Wait till pipeline preview is in running state | ||
Then Open and capture pipeline preview logs | ||
Then Verify the preview run status of pipeline in the logs is "succeeded" | ||
Then Close the pipeline logs | ||
Then Close the preview | ||
Then Deploy the pipeline | ||
Then Run the Pipeline in Runtime | ||
Then Enter runtime argument value "projectId" for key "gcsProjectId" | ||
Then Enter runtime argument value "serviceAccountType" for key "serviceAccountType" | ||
Then Enter runtime argument value "serviceAccountType" for key "serviceAccountType" | ||
Then Enter runtime argument value "serviceAccount" for key "serviceAccount" | ||
Then Enter runtime argument value for GCS sink property path key "gcsSinkPath" | ||
Then Enter runtime argument value "gcsPathDateSuffix" for key "gcsPathSuffix" | ||
Then Enter runtime argument value "csvFormat" for key "gcsFormat" | ||
Then Enter runtime argument value "writeHeader" for key "WriteHeader" | ||
Then Enter runtime argument value "contentType" for key "gcsContentType" | ||
Then Enter runtime argument value "gcsSinkBucketLocation" for key "gcsSinkLocation" | ||
Then Enter runtime argument value "outputFileNameBase" for key "OutFileNameBase" | ||
Then Enter runtime argument value "gcsFileSysProperty" for key "FileSystemPr" | ||
Then Enter runtime argument value "cmekGCS" for GCS cmek property key "cmekGCS" if GCS cmek is enabled | ||
Then Run the Pipeline in Runtime with runtime arguments | ||
Then Wait till pipeline is in running state | ||
Then Open and capture logs | ||
Then Verify the pipeline status is "Succeeded" | ||
Then Verify data is transferred to target GCS bucket | ||
Then Validate the cmek key "cmekGCS" of target GCS bucket if cmek is enabled |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -95,7 +95,7 @@ Feature: GCS sink - Verification of GCS Sink plugin | |
| parquet | application/octet-stream | | ||
| orc | application/octet-stream | | ||
|
||
@GCS_SINK_TEST @BQ_SOURCE_TEST | ||
@BQ_SOURCE_TEST @GCS_SINK_TEST | ||
Scenario Outline: To verify data is getting transferred successfully from BigQuery to GCS with combinations of contenttype | ||
Given Open Datafusion Project to configure pipeline | ||
When Source is BigQuery | ||
|
@@ -265,3 +265,113 @@ Feature: GCS sink - Verification of GCS Sink plugin | |
Then Open and capture logs | ||
Then Verify the pipeline status is "Succeeded" | ||
Then Verify data is transferred to target GCS bucket | ||
|
||
@BQ_SOURCE_TEST @GCS_SINK_TEST | ||
Scenario Outline: To verify data is getting transferred successfully from BigQuery to GCS with contenttype selection | ||
Given Open Datafusion Project to configure pipeline | ||
When Select plugin: "BigQuery" from the plugins list as: "Source" | ||
When Expand Plugin group in the LHS plugins list: "Sink" | ||
When Select plugin: "GCS" from the plugins list as: "Sink" | ||
Then Connect source as "BigQuery" and sink as "GCS" to establish connection | ||
Then Open BigQuery source properties | ||
Then Enter the BigQuery source mandatory properties | ||
Then Validate "BigQuery" plugin properties | ||
Then Close the BigQuery properties | ||
Then Open GCS sink properties | ||
Then Enter GCS property projectId and reference name | ||
Then Enter GCS sink property path | ||
Then Select GCS property format "<FileFormat>" | ||
Then Select GCS sink property contentType "<contentType>" | ||
Then Validate "GCS" plugin properties | ||
Then Close the GCS properties | ||
Then Save and Deploy Pipeline | ||
Then Run the Pipeline in Runtime | ||
Then Wait till pipeline is in running state | ||
Then Open and capture logs | ||
Then Verify the pipeline status is "Succeeded" | ||
Then Verify data is transferred to target GCS bucket | ||
Examples: | ||
| FileFormat | contentType | | ||
| csv | text/csv | | ||
| tsv | text/plain | | ||
|
||
@CMEK @BQ_SOURCE_TEST @GCS_SINK_TEST | ||
Scenario:Validate successful records transfer from BigQuery to GCS with advanced file system properties field | ||
Given Open Datafusion Project to configure pipeline | ||
Then Select plugin: "BigQuery" from the plugins list as: "Source" | ||
When Expand Plugin group in the LHS plugins list: "Sink" | ||
When Select plugin: "GCS" from the plugins list as: "Sink" | ||
Then Open BigQuery source properties | ||
Then Enter BigQuery property reference name | ||
Then Enter BigQuery property projectId "projectId" | ||
Then Enter BigQuery property datasetProjectId "projectId" | ||
Then Enter BigQuery property dataset "dataset" | ||
Then Enter BigQuery source property table name | ||
Then Override Service account details if set in environment variables | ||
Then Enter BiqQuery property encryption key name "cmekBQ" if cmek is enabled | ||
Then Validate output schema with expectedSchema "bqSourceSchema" | ||
Then Validate "BigQuery" plugin properties | ||
Then Close the BigQuery properties | ||
Then Open GCS sink properties | ||
Then Override Service account details if set in environment variables | ||
Then Enter the GCS sink mandatory properties | ||
Then Enter GCS File system properties field "gcsFileSysProperty" | ||
Then Validate "GCS" plugin properties | ||
Then Close the GCS properties | ||
Then Connect source as "BigQuery" and sink as "GCS" to establish connection | ||
Then Save the pipeline | ||
Then Preview and run the pipeline | ||
Then Wait till pipeline preview is in running state | ||
Then Open and capture pipeline preview logs | ||
Then Verify the preview run status of pipeline in the logs is "succeeded" | ||
Then Close the pipeline logs | ||
Then Click on preview data for GCS sink | ||
Then Verify preview output schema matches the outputSchema captured in properties | ||
Then Close the preview data | ||
Then Deploy the pipeline | ||
Then Run the Pipeline in Runtime | ||
Then Wait till pipeline is in running state | ||
Then Open and capture logs | ||
Then Verify the pipeline status is "Succeeded" | ||
Then Verify data is transferred to target GCS bucket | ||
|
||
@BQ_SOURCE_TEST @GCS_SINK_TEST @GCS_Sink_Required | ||
Scenario Outline: To verify successful data transfer from BigQuery to GCS for different formats with write header true | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This scenario should be from GCS source to GCS sink right? Re-check and change accordingly. And why are we making it a macro scenarios, it is already covered in macro enabled scenario anyways. |
||
Given Open Datafusion Project to configure pipeline | ||
Then Select plugin: "BigQuery" from the plugins list as: "Source" | ||
When Expand Plugin group in the LHS plugins list: "Sink" | ||
When Select plugin: "GCS" from the plugins list as: "Sink" | ||
Then Connect source as "BigQuery" and sink as "GCS" to establish connection | ||
Then Open BigQuery source properties | ||
Then Enter the BigQuery source mandatory properties | ||
Then Validate "BigQuery" plugin properties | ||
Then Close the BigQuery properties | ||
Then Open GCS sink properties | ||
Then Enter GCS property projectId and reference name | ||
Then Enter GCS sink property path | ||
Then Select GCS property format "<FileFormat>" | ||
Then Click on the Macro button of Property: "writeHeader" and set the value to: "WriteHeader" | ||
Then Validate "GCS" plugin properties | ||
Then Close the GCS properties | ||
Then Save the pipeline | ||
Then Preview and run the pipeline | ||
Then Enter runtime argument value "writeHeader" for key "WriteHeader" | ||
Then Run the preview of pipeline with runtime arguments | ||
Then Wait till pipeline preview is in running state | ||
Then Open and capture pipeline preview logs | ||
Then Verify the preview run status of pipeline in the logs is "succeeded" | ||
Then Close the pipeline logs | ||
Then Close the preview | ||
Then Deploy the pipeline | ||
Then Run the Pipeline in Runtime | ||
Then Enter runtime argument value "writeHeader" for key "WriteHeader" | ||
Then Run the Pipeline in Runtime with runtime arguments | ||
Then Wait till pipeline is in running state | ||
Then Open and capture logs | ||
Then Verify the pipeline status is "Succeeded" | ||
Then Verify data is transferred to target GCS bucket | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Add the validation steps in all the scenarios. |
||
Examples: | ||
| FileFormat | | ||
| csv | | ||
| tsv | | ||
| delimited | |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -65,3 +65,39 @@ Feature: GCS sink - Verify GCS Sink plugin error scenarios | |
Then Select GCS property format "csv" | ||
Then Click on the Validate button | ||
Then Verify that the Plugin Property: "format" is displaying an in-line error message: "errorMessageInvalidFormat" | ||
|
||
@BQ_SOURCE_TEST @GCS_SINK_TEST | ||
Scenario: To verify and validate the Error message in pipeline logs after deploy with invalid bucket path | ||
Given Open Datafusion Project to configure pipeline | ||
When Select plugin: "BigQuery" from the plugins list as: "Source" | ||
When Expand Plugin group in the LHS plugins list: "Sink" | ||
When Select plugin: "GCS" from the plugins list as: "Sink" | ||
Then Connect source as "BigQuery" and sink as "GCS" to establish connection | ||
Then Open BigQuery source properties | ||
Then Enter the BigQuery source mandatory properties | ||
Then Validate "BigQuery" plugin properties | ||
Then Close the BigQuery properties | ||
Then Open GCS sink properties | ||
Then Enter GCS property projectId and reference name | ||
Then Enter GCS property "path" as macro argument "gcsSinkPath" | ||
Then Select GCS property format "csv" | ||
Then Click on the Validate button | ||
Then Close the GCS properties | ||
Then Save the pipeline | ||
Then Preview and run the pipeline | ||
Then Enter runtime argument value "gcsInvalidBucketNameSink" for key "gcsSinkPath" | ||
Then Run the preview of pipeline with runtime arguments | ||
Then Wait till pipeline preview is in running state | ||
Then Open and capture pipeline preview logs | ||
Then Close the pipeline logs | ||
Then Close the preview | ||
Then Deploy the pipeline | ||
Then Run the Pipeline in Runtime | ||
Then Enter runtime argument value "gcsInvalidBucketNameSink" for key "gcsSinkPath" | ||
Then Run the Pipeline in Runtime with runtime arguments | ||
Then Wait till pipeline is in running state | ||
Then Verify the pipeline status is "Failed" | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Add open and capture logs step |
||
Then Open Pipeline logs and verify Log entries having below listed Level and Message: | ||
| Level | Message | | ||
| ERROR | errorMessageInvalidBucketNameSink | | ||
Then Close the pipeline logs |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Add the validation for file format as well