-
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
Additional Steps for BQ_Source #1472
base: develop
Are you sure you want to change the base?
Additional Steps for BQ_Source #1472
Conversation
Thanks for your pull request! It looks like this may be your first contribution to a Google open source project. Before we can look at your pull request, you'll need to sign a Contributor License Agreement (CLA). View this failed invocation of the CLA check for more information. For the most up to date status, view the checks section at the bottom of the pull request. |
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.
Please update the PR description to reflect details and context about the changes. For eg: #1444 (comment)
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.
The BUTs seems to be failing, please take a look and fix the errors.
…ugin: Added and modified.
Description: Updated the BigQuery plugin to include additional steps for better handling. Modified Files: Cdfplugin property locators.java File Modified: src/e2e-test/java/io/cdap/plugin/utils/CdfPluginPropertyLocator.java Unit Tests: No changes made to unit tests. |
Build with unit tests is still failing, there are a bunch of checkstyle errors, for eg:
Please check and fix the same |
pom.xml
Outdated
@@ -86,7 +86,7 @@ | |||
<google.cloud.storage.version>2.3.0</google.cloud.storage.version> | |||
<google.cloud.datastore.version>1.105.1</google.cloud.datastore.version> | |||
<google.protobuf.java.version>3.19.4</google.protobuf.java.version> | |||
<google.tink.version>1.3.0-rc3</google.tink.version> | |||
<google.tink.version>1.5.0</google.tink.version> |
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.
why this change?
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.
I encountered dependency errors while running mvn clean install after resolving all the checkstyle issues. The build was failing due to the outdated version of google.tink.version. Updating it to 1.5.0 resolved the issue, and no other changes were made.
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.
please do not make dependency changes in the e2e tests PR.
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.
Refactor CdfPluginPropertyLocator alignment and update build dependencies.
-Fixed indentation alignment for partitionFrom, partitionTo, filter and Output Schema.
-Updated pom.xml as it is.
.put("projectId", CdfPluginPropertyLocator.PROJECT_ID) | ||
.put("datasetProjectId", CdfPluginPropertyLocator.DATASET_PROJECT_ID) | ||
.put("dataset", CdfPluginPropertyLocator.DATASET) | ||
.put("table", CdfPluginPropertyLocator.TABLE) | ||
.put("format", CdfPluginPropertyLocator.FORMAT) | ||
.put("path", CdfPluginPropertyLocator.PATH) | ||
.put("sampleSize", CdfPluginPropertyLocator.SAMPLE_SIZE) | ||
.put("delimiter", CdfPluginPropertyLocator.DELIMITER) | ||
.put("skipHeader", CdfPluginPropertyLocator.SKIP_HEADER) | ||
.put("pathSuffix", CdfPluginPropertyLocator.SUFFIX) | ||
.put("encryptionKeyName", CdfPluginPropertyLocator.CMEK_KEY) | ||
.put("serviceAccountType", CdfPluginPropertyLocator.SERVICE_ACCOUNT_TYPE) | ||
.put("serviceAccountFilePath", CdfPluginPropertyLocator.SERVICE_ACCOUNT_PATH) | ||
.put("serviceAccountJSON", CdfPluginPropertyLocator.SERVICE_ACCOUNT_JSON) | ||
.put("truncateTable", CdfPluginPropertyLocator.TRUNCATE_TABLE) | ||
.put("updateTableSchema", CdfPluginPropertyLocator.UPDATE_TABLE_SCHEMA) | ||
.put("topic", CdfPluginPropertyLocator.PUBSUB_TOPIC) | ||
.put("maximumBatchCount", CdfPluginPropertyLocator.PUBSUB_MAXIMUM_BATCH_COUNT) | ||
.put("maximumBatchSize", CdfPluginPropertyLocator.PUBSUB_MAXIMUM_BATCH_SIZE) | ||
.put("publishDelayThreshold", CdfPluginPropertyLocator.PUBSUB_PUBLISH_DELAY_THRESHOLD) | ||
.put("retryTimeout", CdfPluginPropertyLocator.PUBSUB_RETRY_TIMEOUT) | ||
.put("errorThreshold", CdfPluginPropertyLocator.PUBSUB_ERROR_THRESHOLD) | ||
.put("outputSchema", CdfPluginPropertyLocator.OUTPUT_SCHEMA_MACRO_INPUT) | ||
.put("objectsToDelete", CdfPluginPropertyLocator.GCS_DELETE_OBJECTS_TO_DELETE) | ||
.put("objectsToCreate", CdfPluginPropertyLocator.GCS_CREATE_OBJECTS_TO_CREATE) | ||
.put("createFailIfObjectExists", CdfPluginPropertyLocator.GCS_CREATE_FAIL_IF_OBJECT_EXISTS) | ||
.put("gcsMoveSourcePath", CdfPluginPropertyLocator.GCS_MOVE_SOURCE_PATH) | ||
.put("gcsMoveDestinationPath", CdfPluginPropertyLocator.GCS_MOVE_DESTINATION_PATH) | ||
.put("partitionFrom", CdfPluginPropertyLocator.PARTITION_START_DATE) | ||
.put("partitionTo", CdfPluginPropertyLocator.PARTITION_END_DATE) | ||
.put("filter", CdfPluginPropertyLocator.FILTER) | ||
.put("Output Schema-macro-input", CdfPluginPropertyLocator.OUTPUT_SCHEMA) | ||
.build(); |
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.
why this change?
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.
I was unable to add my steps properly in this field because the alignments were incorrect. To fix this, I copied and pasted the same content and added my steps without making any other changes.
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.
please fix the code style in your editor.
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.
Refactor CdfPluginPropertyLocator alignment and update build dependencies.
-Fixed indentation alignment for partitionFrom, partitionTo, filter and Output Schema.
-Updated pom.xml as it is.
Then Replace input plugin property: "table" with value: "bqSourceTable" | ||
Then Click on the Get Schema button | ||
Then Enter BigQuery source properties partitionFrom and partitionTo | ||
Then Validate BigQuery source incorrect property error for Partition Start date "<property>" value "<value>" |
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.
@Praveena2607 I don't think the internal review comments have been addressed. Please address all the internal review comments provided earlier in this PR as well. Ref Praveena2607#1
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.
As discussed over call, Please resolve all the discussed points and mentioned in internal PR. To use the latest framework steps in all scenarios, for entering the values in property, for validating inline error messages, for selecting output schema macro.
…cies. -Fixed indentation alignment for partitionFrom, partitionTo, filter and Output Schema. -Updated pom.xml for as it is.
Then Validate the cmek key "cmekGCS" of target GCS bucket if cmek is enabled | ||
|
||
@CMEK @BQ_SOURCE_TEST @GCS_SINK_TEST | ||
Scenario:Validate successful records transfer from BigQuery to GCS with macro arguments for filter and outputschema |
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.
Output schema macro step is not present in scenario but in title it is written. Make sure if not using in scenario remove from title, and add in the scenario where step is used.
Scenario:Validate successful records transfer from BigQuery to GCS with macro arguments for filter and outputschema | ||
Given Open Datafusion Project to configure pipeline | ||
When Source is BigQuery | ||
When Sink is GCS |
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.
Use the latest steps from framework.
Then Enter BigQuery property "serviceAccountJSON" as macro argument "serviceAccount" | ||
Then Enter BigQuery property "dataset" as macro argument "bqDataset" | ||
Then Enter BigQuery property "table" as macro argument "bqSourceTable" | ||
Then Enter BigQuery source property output schema "outputSchema" as macro argument "bqOutputSchema" |
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.
Use the existing step discussed earlier, for selecting macro action for output schema.
@@ -260,4 +264,124 @@ public void validateRecordsTransferredToTargetTableIsEqualToNumberOfRecordsFromS | |||
BeforeActions.scenario.write("Number of records transferred from source table to target table:" + count); | |||
Assert.assertEquals(count, countRecordsTarget); | |||
} | |||
|
|||
@Then("Enter BigQuery source properties partitionFrom and partitionTo") |
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.
No need to add the step definition. Please make use of existing steps. This was discussed may times in our calls.
CdfBigQueryPropertiesActions.enterPartitionEndDate(new SimpleDateFormat("dd-MM-yyyy") | ||
.format(DateUtils.addDays(new Date(), 1))); | ||
} | ||
@Then("Validate BigQuery source incorrect property error for Partition Start date {string} value {string}") |
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.
No need to add the step definition. Please make use of existing steps.
Assert.assertEquals(expectedColor, actualColor); | ||
} | ||
|
||
@Then("Validate BigQuery source incorrect property error for Partition End date {string} value {string}") |
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.
Here as well.
Assert.assertEquals(expectedColor, actualColor); | ||
} | ||
|
||
@Then("Validate BigQuery source incorrect property error for reference name{string} value {string}") |
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.
Here as well.
|
||
} | ||
|
||
@Then("Enter BigQuery source properties filter") |
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.
All the step definitions added here in base file are all not needed. Use the existing steps, and execute the tests.
pom.xml
Outdated
@@ -86,7 +86,7 @@ | |||
<google.cloud.storage.version>2.3.0</google.cloud.storage.version> | |||
<google.cloud.datastore.version>1.105.1</google.cloud.datastore.version> | |||
<google.protobuf.java.version>3.19.4</google.protobuf.java.version> | |||
<google.tink.version>1.3.0-rc3</google.tink.version> | |||
<google.tink.version>1.3.0</google.tink.version> |
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.
this is still not reverted to older version
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.
Now, It is reverted and please review.
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.
please revert back the checkstyle changes in existing steps.
import io.cdap.e2e.pages.actions.CdfPluginPropertiesActions; | ||
import io.cdap.e2e.pages.actions.CdfStudioActions; | ||
import io.cdap.e2e.pages.locators.CdfBigQueryPropertiesLocators; | ||
import io.cdap.e2e.pages.locators.CdfStudioLocators; | ||
import io.cdap.e2e.utils.BigQueryClient; | ||
import io.cdap.e2e.utils.ConstantsUtil; | ||
import io.cdap.e2e.utils.ElementHelper; | ||
import io.cdap.e2e.utils.PluginPropertyUtils; | ||
import io.cdap.e2e.utils.SeleniumHelper; | ||
import io.cdap.e2e.utils.WaitHelper; | ||
import io.cdap.plugin.common.stepsdesign.TestSetupHooks; | ||
import io.cdap.plugin.utils.CdfPluginPropertyLocator; | ||
import io.cdap.plugin.utils.E2EHelper; | ||
import io.cdap.plugin.utils.E2ETestConstants; | ||
import io.cucumber.java.en.Then; | ||
import org.apache.commons.lang3.StringUtils; | ||
import org.apache.commons.lang3.time.DateUtils; | ||
import org.junit.Assert; | ||
import stepsdesign.BeforeActions; | ||
|
||
import java.io.IOException; | ||
import java.text.SimpleDateFormat; | ||
import java.util.Date; | ||
import java.util.Optional; | ||
import java.util.Properties; |
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.
Any reason we are adding additional imports here? Don't see them being used in the file anywhere
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.
Thank you for pointing this out. I did not manually add any of these imports. This branch was created by cloning from the master, and it seems these additional imports were automatically included during the branching process. could you please suggest how we should proceed?
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.
I have now removed the unnecessary imports that are not in use.
Please verify the Scenarios.