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

Make link to issue template url safe #3508

Merged
merged 2 commits into from
Jan 20, 2025
Merged

Conversation

JCZuurmond
Copy link
Member

@JCZuurmond JCZuurmond commented Jan 10, 2025

Changes

Make link to issue template url safe using Python's urllib

Linked issues

Introduced in #3498

  • Manually tested

@JCZuurmond JCZuurmond added the migrate/code Abstract Syntax Trees and other dark magic label Jan 10, 2025
@JCZuurmond JCZuurmond self-assigned this Jan 10, 2025
@JCZuurmond JCZuurmond requested a review from a team as a code owner January 10, 2025 08:21
Copy link

github-actions bot commented Jan 10, 2025

✅ 58/58 passed, 2 skipped, 26m8s total

Running from acceptance #8039

Copy link
Contributor

@asnare asnare left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't think this works as intended.

Please test the URL, and ensure that the source code being embedded in the URL includes each of the following characters at least once somewhere: +, &, %, (space) and =.

src/databricks/labs/ucx/source_code/python/python_ast.py Outdated Show resolved Hide resolved
@JCZuurmond JCZuurmond force-pushed the fix/issue-template-url-safe branch from 4cc6eef to e770cff Compare January 20, 2025 13:07
@JCZuurmond JCZuurmond requested a review from asnare January 20, 2025 13:08
@JCZuurmond JCZuurmond added this pull request to the merge queue Jan 20, 2025
Merged via the queue into main with commit a517cb9 Jan 20, 2025
7 checks passed
@JCZuurmond JCZuurmond deleted the fix/issue-template-url-safe branch January 20, 2025 16:01
@gueniai gueniai mentioned this pull request Jan 21, 2025
gueniai added a commit that referenced this pull request Jan 23, 2025
* Implement disposition field in SQL backend
([#3477](#3477)). In this
release, we've added a new `query_statement_disposition` configuration
option for the SQL backend used in the `databricks labs ucx`
command-line interface. This option allows users to choose the
disposition method for running large SQL queries during assessment
results export, preventing failures in cases of large workspaces with
high volumes of findings. The new option is included in the `config.yml`
file and used in the SqlBackend definition. The commit also includes
updates to the `workspace_cli.py` file and addresses issue
[#3447](#3447). The
`disposition` parameter has been added to the
`StatementExecutionBackend` method, and the `Disposition` enum from the
`databricks.sdk.service.sql` module has been added to the `config.py`
file. The changes have been manually tested and are included in the
modified `databricks labs install ucx` and `databricks labs ucx
export-assessment` commands.
* AWS role issue with external locations pointing to the root of a
storage account
([#3510](#3510)). This
release includes a modification to enhance AWS role access for external
locations pointing to the root of a storage account, addressing issue
[#3510](#3510) and closing
issue [#3505](#3505). The
`aws.py` file in the `src/databricks/labs/ucx/assessment/` directory has
been updated to improve S3 bucket ARN pattern matching, now allowing
optional trailing slashes for greater flexibility. In the `access.py`
file within the `aws` directory of the `databricks/labs/ucx` package,
the `_identify_missing_paths` method now checks if the
`role.resource_path` is a parent of the external location path or if
they match exactly, allowing root-level external locations to be
recognized as compatible with AWS roles. A new method,
`AWSUCRoleCandidate`, has been added to the `AWSResources` class, and
several test cases have been updated or added to ensure proper
functionality with UC roles and AWS resources, including handling cases
with multiple role creations.
* Added assert to make sure installation is finished before
re-installation
([#3546](#3546)). In the
latest release, we've addressed an issue (commit 3546) where the
reinstallation of a software component was starting before the initial
installation was complete, causing a warning message to be suppressed
and the test to fail. To rectify this, we have enhanced the integration
tests and added an assert to ensure that the installation is finished
before attempting reinstallation. A new function called
`wait_for_installation_to_finish` has been introduced to manage the
waiting process. Furthermore, we have updated the
`test_compare_remote_local_install_versions` function to accept
`installation_ctx` instead of `ws` as a parameter, ensuring proper
configuration and loading of the installation before test execution.
These changes guarantee that the test will pass if the installation is
finished before the reinstallation is attempted.
* Added dashboards to migration progress dashboard
([#3314](#3314)). The
release notes have been updated to reflect the new features and changes
in the migration progress dashboard. This commit includes the addition
of dashboards to track the migration progress, with linting resources
added to ensure code quality. The commit also modifies the existing
dashboard "Migration [main]" and updates both unit and integration
tests. Specific new files and methods have been added to enhance
functionality, including the tracking of dashboard migration, and new
fixtures have been introduced to improve testing. The changes depend on
several issues and break up others to progress functionality. Overall,
this commit enhances the migration progress dashboard's capabilities,
making it more efficient and reliable for tracking migration progress.
* Added history log encoder for dashboards
([#3424](#3424)). A history
log encoder for dashboards has been added, addressing issues
[#3368](#3368) and
[#3369](#3369), which
modifies the existing `experimental-migration-progress` workflow. This
enhancement introduces a `DashboardProgressEncoder` class that encodes
Dashboard objects into Historical records, appending inventory snapshots
to the history table. The changes include adding new methods for
handling object types such as directories, and updating the `is_delta`
property of the `Table` class. The commit also includes new tests:
manually tested, unit tests added, and integration tests added.
Specifically, `test_table_progress_encoder_table_failures` has been
updated to include a new parameter, `is_migrated_table`, which, if set
to False, adds `Pending migration` to the list of failures. The
`is_used_table` parameter has been removed, and its functionality is no
longer part of this commit. The changes are tested through manual, unit,
and integration testing, ensuring the proper encoding of migration
progress and identifying relevant failures.
* Create specific failure for Python syntax error while parsing with
Astroid ([#3498](#3498)). In
this release, the Python linting-related code has been updated to
introduce a specific failure type for syntax errors that occur while
parsing code using Astroid. Previously, such errors resulted in a
generic `system-error` message, but with this change, a new failure type
called `python-parse-error` has been introduced. This new error type
includes the start and end line and column numbers of the error and is
accompanied by a new issue URL for reporting the error on the UCX
GitHub. The `system-error` failure type has been renamed to
`python-parse-error` to maintain consistency with the `sql-parse-error`
failure type. Additionally, a new method `Tree.maybe_parse()` has been
introduced to improve error detection and reporting during Python
linting. A unit test has been added to ensure the new failure type is
working as intended, and a generic failure is kept for directing users
to create GitHub issues for surfacing other issues.
* DBR 16 and later support
([#3481](#3481)). This
release adds support for Databricks Runtime (DBR) 16 and later, enabling
the optional conversion of Hive Metastore (HMS) tables to external
tables within the `migrate-tables` workflow. The change includes a new
static method `_get_entity_storage_locations` to check for the presence
of the `entityStorageLocations` property on table metadata. The existing
`_convert_hms_table_to_external` method has been updated to use this new
method and to include the `entityStorageLocations` constructor argument
if present. The changes have been manually tested for DBR 16, tested
with existing integration tests for DBR 15, and verified on the staging
environment with DBR 16. Additionally, the `skip_job_wait=True`
parameter has been added to specific test function calls to improve test
execution time. This release also resolves an issue with a failed test
in DBR16 due to a JDK update.
* Delete stale code: `NotebookLinter._load_source_from_run_cell`
([#3529](#3529)). In this
release, we have improved the code linting functionality in the
NotebookLinter class of our open-source library by removing the
`_load_source_from_run_cell` method in the sources.py file. This method,
previously used to load source code from run cells in a notebook, has
been identified as stale code and is no longer required. Consequently,
this change affects the `databricks labs ucx lint-local-code` command
and results in cleaner and more maintainable code. Furthermore, updated
and added unit tests have been included in this commit, which have been
manually tested to ensure that the changes do not adversely impact
existing functionality, thus progressing issue
[#3514](#3514).
* Exclude ucx dashboards from Lakeview dashboard crawler
([#3450](#3450)). In this
release, the functionality of the `assessment` workflow has been
improved to exclude certain dashboard IDs from the Lakeview dashboard
crawler. This change has been made to address the issue of false
positive dashboards and affects the `_crawl` method in the
`dashboards.py` file. The excluded dashboard IDs are now obtained from
the `install_state.dashboards` object. Additionally, new methods have
been added to the `test_dashboards.py` file in the `unit/assessment`
directory to test the exclusion functionality, including a test to
ensure that the exclude parameter takes priority over the include
parameter. The commit also includes unit tests, manual tests, and
screenshots to verify the changes on the staging environment. Overall,
this modification enhances the accuracy of the dashboard crawler and
simplifies the process of identifying and assessing relevant dashboards.
* Fixed issue in installing UCX on UC enabled workspace
([#3501](#3501)). This pull
request introduces changes to the UCX installer to address an issue
([#3420](#3420)) with
installing UCX on UC-enabled workspaces. It updates the UCX policy by
changing the `spark_version` parameter from `fixed` to `allowlist` with
a default value, allowing the cluster definition to take `single_user`
and `user_isolation` values instead of `Legacy_Single_User` and
'Legacy_Table_ACL'. Additionally, the job definition has been updated to
use the default value when not explicitly provided. The changes are
implemented in the `test_policy.py` file and impact the
`test_job_cluster_policy` and `test_job_cluster_on_uc_enabled_workspace`
methods. The pull request also includes updates to unit tests and
integration tests to ensure the correct behavior of the updated UCX
policy and job definition. The target audience is software engineers
adopting this project, with changes involving adjusting policy
definitions and testing job cluster behavior under different
configurations. Issue
[#3501](#3501) is also
resolved with these changes.
* Fixed typo in workflow name (in error message)
([#3491](#3491)). This PR
includes a fix for a minor typo in the error message of the
`validate_groups_permissions` method in the `workflows.py` file. The
typo resulted in the incorrect spelling of `group` as `groups` in the
workflow name. The fix simply changes `groups` to `group` in the error
message, ensuring accurate workflow name display. The functionality of
the code remains unaffected by this change, and no new methods have been
added. To clarify, the `validate_groups_permissions` method verifies
whether group permissions have been migrated correctly, and if not,
raises a ValueError with an error message suggesting the use of the
`validate-group-permissions` workflow for validation after the API has
caught up. This fix resolves the typo issue and maintains the expected
behavior of the code.
* Make link to issue template url safe
([#3508](#3508)). In this
commit, the `_definitely_failure` function in the `python_ast.py` file
has been modified to make the link to the issue template URL safe using
Python's `urllib`. This change ensures that any special characters in
the source code passed to the function will be properly displayed in the
issue template. If the source code cannot be parsed, the function
creates a link to the issue template for reporting a bug in the UCX
library, including the source code as part of the issue body. With this
commit, the source code is now passed through the
`urllib.parse.quote_plus` function before being added to the issue body,
making it url-safe and improving the robustness and user-friendliness of
the library. This change has been introduced in issue
[#3498](#3498) and has been
manually tested.
* Refactor `PipelineMigrator`'s to add `include_pipeline_ids`
([#3495](#3495)). In this
refactoring, the `PipelineMigrator` has been updated to introduce an
`include_pipeline_ids` option, replacing the previous
`skip_pipeline_ids` flag. This change allows users to specify the list
of pipelines to migrate, providing better control over the migration
process. The `PipelinesMigrator` constructor,
`_get_pipelines_to_migrate`, and `migrate_pipelines` methods have been
modified to accommodate this new flag. The `_migrate_pipeline` method
now accepts the pipeline ID instead of a `PipelineInfo` object.
Additionally, the unit tests have been updated to include the new
`include_flag` parameter, which facilitates testing various scenarios
with different pipeline lists. Although the commit does not show changes
to test files, integration tests should be updated to reflect the new
`include-pipeline-ids` flag functionality. This improvement resolves
issue [#3492](#3492) and
enhances the overall flexibility of the `PipelineMigrator`.
* Rename Python AST's `Tree` methods for clarity
([#3524](#3524)). In this
release, the `Tree` class in the Python AST library has been updated for
improved code clarity and functionality. The `append_` methods have been
renamed to `attach_` for better accuracy, and now include docstrings for
increased understanding. These methods have been updated to always
return `None`. A new method, `attach_child_tree`, has been added,
allowing for traversal from both parent and child and propagating any
module references. Several new methods and functionalities have been
introduced to improve the class, while extensive unit testing has been
conducted to ensure functionality. Additionally, the diff includes test
cases for various functionalities, such as inferring values when
attaching trees and verifying spark module propagation, as well as tests
to ensure that certain operations are not supported. This change, linked
to issues [#3514](#3514) and
[#3520](#3520), may affect
any code that calls these methods and relies on their return values.
However, the added docstrings and unit tests will help ensure your code
continues to function correctly.
* Schedule the migration progress workflow to run daily
([#3485](#3485)). This PR
introduces changes to the UCX installation process to schedule the
migration progress workflow to run automatically once a day, with the
default schedule set to run at 5 a.m. UTC. It includes refactoring the
plumbing used for managing and installing workflows, enabling them to
have a Cron-based schedule. The relevant user documentation has been
updated, and the existing `migration-progress-experimental` workflow has
been modified. Additionally, unit and integration tests have been
added/modified to ensure the proper functioning of the updated code, and
new functions have been added to verify the workflow's schedule and task
detection.
* Scope crawled pipelines in PipelineCrawler
([#3513](#3513)). In this
release, the `PipelineCrawler` class in the `pipelines.py` file has been
updated to include a new optional argument `include_pipeline_ids` in its
constructor. This argument allows users to filter the pipelines that are
crawled by specifying a list of pipeline IDs. The `_crawl` method has
been modified to check if `include_pipeline_ids` is not `None` and to
filter the list of pipelines accordingly. The class now also checks if
each pipeline exists before getting its configuration, and logs a
warning message if the pipeline is not found. Previously, a `NotFound`
exception was raised. Additionally, the code has been updated to use
`pipeline.spec.configuration` instead of
`pipeline_response.spec.configuration` to get the pipeline
configuration. These changes have been tested through new and updated
unit tests, including a test for handling creators' user names. Overall,
these updates provide improved functionality and flexibility for
crawling pipelines.
* Updated databricks-labs-blueprint requirement from <0.10,>=0.9.1 to
>=0.9.1,<0.11
([#3519](#3519)). In this
release, we have updated the version requirement of the
`databricks-labs-blueprint` package to be greater than or equal to 0.9.1
and less than 0.11. This change allows us to use the latest version of
the package and includes bug fixes and dependency updates. The hosted
runner has been patched in version 0.10.1 to address issues with
publishing artifacts in the release workflow. Release notes for previous
versions are also provided in the commit. These updates are intended to
improve the overall functionality and stability of the library.
* Updated databricks-sdk requirement from <0.41,>=0.40 to >=0.40,<0.42
([#3553](#3553)). In this
release, the `databricks-sdk` package requirement has been updated to
version 0.41.0, which brings new features, improvements, bug fixes, and
API changes. Among the new features are the addition of
'serving.http_request' for calling external functions, and recovery on
download failures in the Files API client. Although the specifics of the
functionality added and changed are not detailed, the focus of this
release appears to be on bug fixes and internal enhancements.
Additionally, the API has undergone changes, including added and altered
methods and fields, however, specific information about these changes
has not been provided in the release notes.
* Updated sqlglot requirement from <26.1,>=25.5.0 to >=25.5.0,<26.2
([#3500](#3500)). A critical
update has been implemented in this release for the `sqlglot` package,
which has been updated to version 25.5.0 or higher, but less than 26.2.
This change is essential to leverage the latest version of sqlglot while
avoiding any breaking changes introduced in version 26.1. The new
version includes several breaking changes, new features, bug fixes, and
modifications to various dialects such as hive, postgres, tsql, and
sqlite. Moreover, the tokenizer has been updated to accept
underscore-separated number literals. However, the specific impact of
these changes on the project is not detailed in the commit message, and
software engineers should thoroughly test and review the changes to
ensure seamless functionality.
* Updated sqlglot requirement from <26.2,>=25.5.0 to >=25.5.0,<26.3
([#3528](#3528)). In this
update, we have modified the version constraint for the `sqlglot`
dependency from `>=25.5.0,<26.2` to `>=25.5.0,<26.3` in the
`pyproject.toml` file. Sqlglot is a Python-based SQL parser and
optimizer, and this change allows us to adopt the latest version of
sqlglot within the specified version range. This update addresses
potential security vulnerabilities and incorporates performance
enhancements and bug fixes, ensuring that our library remains up-to-date
and secure.
* Updated table-migration workflows to also capture updated migration
progress into the history log
([#3239](#3239)). This pull
request updates the table-migration workflows to log not only the tables
that still need to be migrated, but also the progress of the migration.
The affected workflows include `migrate-tables`,
`migrate-external-hiveserde-tables-in-place-experimental`,
`migrate-external-tables-ctas`, `scan-tables-in-mounts-experimental`,
and `migrate-tables-in-mounts-experimental`. The encoder for
table-history has been refactored to improve control over when the
`TableMigrationStatus` data is refreshed. The documentation has been
updated to reflect the changes in each workflow. Additionally, both unit
and integration tests have been added and updated to ensure the changes
work as intended and resolve any conflicts. A new
`ProgressTrackingInstallation` class has been added to support this
functionality. The changes have been manually tested and include
modifications to the existing workflows, new methods, and a renamed
method. The `mock_workspace_client` function has been replaced, and the
`external_locations.resolve_mount` method and other methods have not
been called. The `TablesCrawler` object's `snapshot` method has been
called once to retrieve the list of tables in the Hive metastore. The
migration record workflow run is also updated to include the workflow
run information in the `workflow_runs` table. These changes are expected
to improve the accuracy and reliability of the table-migration
workflows.

Dependency updates:

* Updated sqlglot requirement from <26.1,>=25.5.0 to >=25.5.0,<26.2
([#3500](#3500)).
* Updated databricks-labs-blueprint requirement from <0.10,>=0.9.1 to
>=0.9.1,<0.11
([#3519](#3519)).
* Updated databricks-sdk requirement from <0.41,>=0.40 to >=0.40,<0.42
([#3553](#3553))
gueniai added a commit that referenced this pull request Jan 23, 2025
*  Implement disposition field in SQL backend ([#3477](#3477)). This commit adds a `query_statement_disposition` configuration option for the SQL backend in the UCX tool, allowing users to specify the disposition of SQL statements during assessment results export and preventing failures when dealing with large workspaces and a large number of findings. The new configuration option is added to the `config.yml` file and used by the `SqlBackend` definition. The `databricks labs install ucx` and `databricks labs ucx export-assessment` commands have been modified to support this new functionality. A new `Disposition` enum has been added to the `databricks.sdk.service.sql` module. This change resolves issue [#3447](#3447) and is related to pull request [#3455](#3455). The functionality has been manually tested.
* AWS role issue with external locations pointing to the root of a storage account ([#3510](#3510)). The `AWSResources` class in the `aws.py` file has been updated to enhance the regular expression pattern for matching S3 bucket names, now including an optional group for trailing slashes and any subsequent characters. This allows for recognition of external locations pointing to the root of a storage account, addressing issue [#3505](#3505). The `access.py` file within the AWS module has also been updated, introducing a new `path` variable and updating a for loop condition to accurately identify missing paths in external locations referencing the root of a storage account. New unit tests have been added to `tests/unit/aws/test_access.py`, including a `test_uc_roles_create_all_roles` method that checks the creation of all possible UC roles when none exist and external locations with and without folders. Additionally, the `backend` fixture has been updated to include a new external location `s3://BUCKET4`, and various tests have been updated to incorporate this location and handle errors appropriately.
* Added assert to make sure installation is finished before re-installation ([#3546](#3546)). In this release, we have added an assertion to ensure that the installation process is completed before attempting to reinstall, addressing a previous issue where the reinstallation was starting before the first installation was finished, causing a warning to not be raised and resulting in a test failure. We have introduced a new function `wait_for_installation_to_finish()`, which retries loading the installation if it is not found, with a timeout of 2 minutes. This function is utilized in the `test_compare_remote_local_install_versions` test to ensure that the installation is finished before proceeding. Furthermore, we have extracted the warning message to a variable `error_message` for better readability. This change enhances the reliability of the installation process.
* Added dashboards to migration progress dashboard ([#3314](#3314)). This commit introduces significant updates to the migration progress dashboard, adding dashboards, linting resources, and modifying existing components. The changes include a new dashboard displaying the number of dashboards pending migration, with the data sourced from the `ucx_catalog.multiworkspace.objects_snapshot` table. The existing 'Migration [main]' dashboard has been updated, and unit and integration tests have been adapted accordingly. The commit also renames several SQL files, updates the percentage UDF, grant, job, cluster, table, and pipeline migration progress queries, and resolves linting compatibility issues related to Unity Catalog. The changes depend on issue [#3424](#3424), progress issue [#3045](#3045), and break up issue [#3112](#3112). The new dashboard aims to enhance the migration process and ensure a smooth transition to the Unity Catalog.
* Added history log encoder for dashboards ([#3424](#3424)). A new history log encoder for dashboards has been added, addressing issues [#3368](#3368) and [#3369](#3369), and modifying the existing `experimental-migration-progress` workflow. This update includes the addition of the `DashboardOwnership` class, used to generate ownership information for dashboards, and the `DashboardProgressEncoder` class, responsible for encoding progress data related to dashboards. The new functionality is tested through manual, unit, and integration testing. In the `Table` class, the `from_table_info` and `from_historical_data` methods have been added, allowing for the creation of `Table` instances from `TableInfo` objects and historical data dictionaries with more flexibility and safety. The `test_tables.py` file in the `integration/progress` directory has also been updated to include a new test function for checking table failures. These changes improve the tracking and management of dashboard IDs, enhance user name retrieval, and ensure the accurate determination of object ownership.
* Create specific failure for Python syntax error while parsing with Astroid ([#3498](#3498)). This commit enhances the Python linting functionality in our open-source library by introducing a specific failure message, `python-parse-error`, for syntax errors encountered during code parsing using Astroid. Previously, a generic `system-error` message was used, which has been renamed to maintain consistency with the existing `sql-parse-error` message. This change provides clearer failure indicators and includes more detailed information about the error location. Additionally, modifications to Python linting-related code, unit test additions, and updates to the README guide users on handling these new error types have been implemented. A new method, `Tree.maybe_parse()`, has been introduced to parse Python code and detect syntax errors, ensuring more precise error handling for users.
* DBR 16 and later support ([#3481](#3481)). This pull request introduces support for Databricks Runtime (DBR) 16 and later in the code that converts Hive Metastore (HMS) tables to external tables within the `migrate-tables` workflow. The changes include the addition of a new static method `_get_entity_storage_locations` to handle the new `entityStorageLocations` property in DBR16 and the modification of the `_convert_hms_table_to_external` method to account for this property. Additionally, the `run_workflow` function in the `assessment` workflow now has the `skip_job_wait` parameter set to `True`, which allows the workflow to continue running even if a job within it fails. The changes have been manually tested for DBR16, verified in a staging environment, and existing integration tests have been run for DBR 15. The diff also includes updates to the `test_table_migration_convert_manged_to_external` method to skip job waiting during testing, enabling the test to run successfully on DBR 16.
* Delete stale code: `NotebookLinter._load_source_from_run_cell` ([#3529](#3529)). In this update, we have removed the stale code `NotebookLinter._load_source_from_run_cell`, which was responsible for loading the source code from a run cell in a notebook. This change is a part of the ongoing effort to address issue [#3514](#3514) and enhances the overall codebase. Additionally, we have modified the existing `databricks labs ucx lint-local-code` command to update the code linting functionality. We have conducted manual testing to ensure that the changes function as intended and have added and modified several unit tests. The `_load_source_from_run_cell` method is no longer needed, as it was part of a deprecated functionality. The modifications to the `databricks labs ucx lint-local-code` command impact the way code linting is performed, ultimately improving the efficiency and maintainability of the codebase.
* Exclude ucx dashboards from Lakeview dashboard crawler ([#3450](#3450)). In this release, we have enhanced the `lakeview_crawler` method in the open-source library to exclude Ucx dashboards and prevent false positives. This has been achieved by adding a new optional argument, `exclude_dashboard_ids`, to the `__init__` method, which takes a list of dashboard IDs to exclude from the crawler. The `_crawl` method has been updated to skip dashboards whose IDs match the ones in the `exclude_dashboard_ids` list. The change includes unit tests and manual testing to ensure proper functionality and has been verified on the staging environment. These updates improve the accuracy and reliability of the dashboard crawler, providing better results for software engineers utilizing this library.
* Fixed issue in installing UCX on UC enabled workspace ([#3501](#3501)). This PR introduces changes to the `ClusterPolicyInstaller` class, updating the `spark_version` policy definition from a fixed value to an allowlist with a default value. This resolves an issue where, when UC is enabled on a workspace, the cluster definition takes on `single_user` and `user_isolation` values instead of `Legacy_Single_User` and 'Legacy_Table_ACL'. The job definition is also updated to use the default value when not explicitly provided. These changes improve compatibility with UC-enabled workspaces, ensuring the correct values for `spark_version` in the cluster definition. The PR includes updates to unit tests and installation tests, addressing issue [#3420](#3420).
* Fixed typo in workflow name (in error message) ([#3491](#3491)). This PR (Pull Request) addresses a minor typo in the error message displayed by the `validate_groups_permissions` method in the `workflows.py` file. The typo occurred in the workflow name mentioned in the error message, where `group` was incorrectly spelled as "groups." The corrected spelling is now `validate-groups-permissions`. This change does not introduce any new methods or modify any existing functionality, but instead focuses on enhancing the clarity and accuracy of the error message. Ensuring that error messages are free from typos and other inaccuracies is essential for maintaining the usability and effectiveness of the code, as it enables users to more easily troubleshoot any issues that may arise during its usage.
* HMS Federation Glue Support ([#3526](#3526)). This commit introduces support for HMS Federation Glue in the open-source library, resolving issue [#3011](#3011). The changes include adding a new command, `migrate-glue-credentials`, to migrate Glue credentials to UC storage credentials in the federation glue for HMS. The `AWSResourcePermissions` class has been updated to include a new parameter `config` for HMS Federation Glue configuration and the `load_uc_compatible_roles` method now accepts an optional `resource_type` parameter for filtering compatible roles based on the provided type. Additionally, the `ExternalLocations` class has been updated to handle S3 resource type when identifying missing external locations. The commit also includes several bug fixes, new classes, methods, and changes to the existing methods to handle AWS Glue resources, and updates to the integration tests. Overall, these changes add significant functionality for AWS Glue support in the HMS Federation Glue feature.
* Make link to issue template url safe ([#3508](#3508)). In this release, we have updated the `python_ast.py` file to enhance the encoding of the link to the issue template for bug reports. By utilizing the `urllib.parse.quote_plus()` function from Python's standard library, we have ensured that any special characters in the provided source code will be properly encoded. This eliminates the risk of issues arising from incorrectly interpreted characters, enhancing the reliability of the bug reporting process. This change, initially introduced in issue [#3498](#3498), has been thoroughly tested to guarantee its correct functioning. The rest of the file remains unaffected, preserving its original functionality.
* Refactor `PipelineMigrator`'s to add `include_pipeline_ids` ([#3495](#3495)). In this release, the `PipelineMigrator` class has been refactored to enhance pipeline migration functionality. The `skip-pipeline-ids` flag has been replaced with `include-pipeline-ids`, allowing users to specify a list of pipelines to migrate, rather than listing pipelines to skip. Additionally, the `exclude_pipeline_ids` functionality has been added to provide even more granularity in pipeline selection. The `migrate_pipelines` method now prioritizes `include_pipeline_ids` and `exclude_pipeline_ids` parameters to determine the list of pipelines for migration. The `_migrate_pipeline` method has been updated to accept a string pipeline ID and now checks if the pipeline has already been migrated. Several support methods, such as `_clone_pipeline`, have also been refactored for improved functionality. Although no new methods were added, the behavior of the `migrate_pipelines` method has changed. While unit tests have been updated to cover the changes, integration tests have not been modified yet. Ensure thorough testing to prevent any new issues or breaks in existing functionality.
* Release v0.54.0 ([#3530](#3530)). 0.54.0 brings several enhancements and bug fixes to the UCX library. A `query_statement_disposition` option is added to the SQL backend to handle large SQL queries during assessment results export, preventing potential failures in large workspaces with high volumes of findings. AWS role compatibility checks are improved for external locations pointing to the root of a storage account. Dashboards are enhanced with added migration progress dashboards and a history log encoder. New failure types are introduced for Python syntax errors during parsing and SQL parsing errors. The library now supports DBR 16 and later versions, with optional conversion of Hive Metastore tables to external tables in the `migrate-tables` workflow. The `PipelineMigrator` functionality is refactored to add an `include_pipeline_ids` parameter for better control over the migration process. Various dependency updates, including `databricks-labs-blueprint`, `databricks-sdk`, and `sqlglot`, are included in this release, which bring new features, improvements, and bug fixes, as well as API changes. Please thoroughly test and review the changes to ensure seamless functionality.
* Rename Python AST's `Tree` methods for clarity ([#3524](#3524)). In this release, we have made significant improvements to the clarity of the Python AST's `Tree` methods in the `python_analyzer.py` file. The `append_` and `extend_` methods have been renamed to `attach_` to better reflect their functionality. These methods now always return `None`. New methods such as `attach_child_tree`, `attach_nodes`, and `extend_globals` have been introduced to enhance the functionality of the library. The `attach_child_tree` method allows for attaching one tree as a child of another tree, propagating module references and enabling traversal from both the parent and child trees. The `attach_nodes` method sets the parent of the attached nodes and adds them to the body of the tree. Additionally, docstrings have been added, and unit testing has been expanded. The changes include modifications to code linting, existing command functionalities, and manual testing to ensure compatibility. These enhancements improve the clarity, functionality, and flexibility of the Python AST's `Tree` methods.
* Revert "Release v0.54.0" ([#3569](#3569)). In version 0.53.1, we have reverted changes from 0.54.0 to address issues with the previous release and ensure proper propagation to PyPI. This version includes various updates such as implementing a disposition field in the SQL backend, improving ARN pattern matching for AWS roles, adding dashboards to migration progress, enhancing Python linting functionality, and adding support for DBR 16 in converting Hive Metastore tables to external tables. We have also excluded UCX dashboards from the Lakeview dashboard crawler, refactored PipelineMigrator's to add include_pipeline_ids, and updated the sqlglot and databricks-labs-blueprint requirements. Additionally, several issues related to installation, typo in workflow name, and table-migration workflows have been fixed. The sqlglot requirement has been updated from <26.1,>=25.5.0 to >=25.5.0,<26.2, and databricks-labs-blueprint from <0.10,>=0.9.1 to >=0.9.1,<0.11. This release does not introduce any new methods or change existing functionality, but focuses on addressing bugs and improving functionality.
* Schedule the migration progress workflow to run daily ([#3485](#3485)). This PR introduces a daily scheduling mechanism for the UCX installation's migration progress workflow, allowing it to run automatically once per day at 5 a.m. UTC. It includes refactoring the plumbing for managing and installing workflows, enabling them to have a Cron-based schedule. Relevant user documentation has been updated, and existing unit and integration tests have been added to ensure the changes function as intended. A new test has been added to verify the migration-progress workflow is installed with a schedule attached, checking the workflow schedule's quartz cron expression, time zone, and pause status, as well as confirming that the workflow is unpaused upon installation. The PR also introduces new methods to manage workflow scheduling and configure cron-based schedules.
* Scope crawled pipelines in PipelineCrawler ([#3513](#3513)). In the latest release, we have introduced a new optional argument, 'include_pipeline_ids', in the constructor of the PipelinesCrawler class located in the 'databricks/labs/ucx/assessment' module. This argument allows users to filter pipelines based on a list of pipeline IDs, improving the crawler's flexibility and efficiency in processing pipelines. In the `_crawl` method of the PipelinesCrawler class, a new behavior has been implemented based on the value of 'include_pipeline_ids'. If the argument is not None, then the method uses the pipeline IDs from this list instead of retrieving all pipelines. Additionally, two unit tests have been added to verify the functionality of this new argument and ensure that the crawler handles cases where a pipeline is not found or its specification is missing. A new parameter, 'force_refresh', has also been added to the `snapshot` function. This release aims to provide a more efficient and customizable pipeline crawling experience for users.
* Updated databricks-labs-blueprint requirement from <0.10,>=0.9.1 to >=0.9.1,<0.11 ([#3519](#3519)). In this update, the requirement for the `databricks-labs-blueprint` library has been changed from version range '<0.10,>=0.9.1>' to a new range of '>=0.9.1,<0.11'. This change allows for the use of the latest version of the library while maintaining compatibility with the current project setup, and is based on information from the library's releases and changelog. The commit includes a list of commits and dependencies for the updated library. This update was automatically implemented by Dependabot, a tool that handles dependency updates and conflict resolution, ensuring a seamless integration process for engineers adopting the project.
* Updated databricks-sdk requirement from <0.41,>=0.40 to >=0.40,<0.42 ([#3553](#3553)). In this release, we have updated the `databricks-sdk` package requirement to permit version 0.41 while excluding version 0.42. This update includes several improvements and new features in version 0.41, such as the addition of the `serving.http_request` method for calling external functions and enhancements to the Files API client to recover from download failures. The commit also includes bug fixes, internal changes, and updates to the API for better functionality and compatibility. It is essential to note that these changes have been made to ensure compatibility with the latest features and improvements in the `databricks-sdk` package.
* Updated sqlglot requirement from <26.1,>=25.5.0 to >=25.5.0,<26.2 ([#3500](#3500)). In this release, we have updated the version requirement for the sqlglot package. The minimum version required is now 25.5.0 and less than 26.2, previously it was 25.5.0 and less than 26.1. This change allows for the most recent version of sqlglot to be installed, while still maintaining compatibility with the current codebase. The update is necessary due to breaking changes introduced in version 26.1.0 of sqlglot, including normalizing before qualifying tables, requiring the `AS` token in CTEs for all dialects except spark and databricks, supporting Unicode in sqlite, mysql, tsql, postgres, and oracle, parsing ASCII into Unicode to facilitate transpilation, and improving transpilation of CHAR[ACTER]_LENGTH. Additionally, several bug fixes and new features have been added in this update.
* Updated sqlglot requirement from <26.2,>=25.5.0 to >=25.5.0,<26.3 ([#3528](#3528)). In this release, we have updated the version constraint for the `sqlglot` dependency in our project's "pyproject.toml" file. The previous constraint allowed versions between 25.5.0 and 26.2, while the new constraint allows versions between 25.5.0 and 26.3. This change was made to ensure that we can use the latest version of sqlglot while also preventing the version from exceeding 26.3. Additionally, the commit includes detailed information about the specific commits and changes made in the updated version of sqlglot, providing valuable insights for software engineers working with this open-source library.
* Updated table-migration workflows to also capture updated migration progress into the history log ([#3239](#3239)). The table-migration workflows have been updated to log not only the tables that still need to be migrated, but also the updated progress information into the history log, ensuring a more comprehensive record of migration progress. The affected workflows include `migrate-tables`, `migrate-external-hiveserde-tables-in-place-experimental`, `migrate-external-tables-ctas`, `scan-tables-in-mounts-experimental`, and `migrate-tables-in-mounts-experimental`. The encoder for table-history has been updated to prevent implicit refresh of `TableMigrationStatus` data during initialization. Additionally, the documentation has been updated to reflect which workflows update which tables. New and updated unit and integration tests, as well as manual testing, have been conducted to ensure the functionality of the changes.

Dependency updates:

 * Updated sqlglot requirement from <26.1,>=25.5.0 to >=25.5.0,<26.2 ([#3500](#3500)).
 * Updated databricks-labs-blueprint requirement from <0.10,>=0.9.1 to >=0.9.1,<0.11 ([#3519](#3519)).
 * Updated databricks-sdk requirement from <0.41,>=0.40 to >=0.40,<0.42 ([#3553](#3553)).
@gueniai gueniai mentioned this pull request Jan 23, 2025
gueniai added a commit that referenced this pull request Jan 23, 2025
* Implement disposition field in SQL backend
([#3477](#3477)). This
commit adds a `query_statement_disposition` configuration option for the
SQL backend in the UCX tool, allowing users to specify the disposition
of SQL statements during assessment results export and preventing
failures when dealing with large workspaces and a large number of
findings. The new configuration option is added to the `config.yml` file
and used by the `SqlBackend` definition. The `databricks labs install
ucx` and `databricks labs ucx export-assessment` commands have been
modified to support this new functionality. A new `Disposition` enum has
been added to the `databricks.sdk.service.sql` module. This change
resolves issue
[#3447](#3447) and is
related to pull request
[#3455](#3455). The
functionality has been manually tested.
* AWS role issue with external locations pointing to the root of a
storage account
([#3510](#3510)). The
`AWSResources` class in the `aws.py` file has been updated to enhance
the regular expression pattern for matching S3 bucket names, now
including an optional group for trailing slashes and any subsequent
characters. This allows for recognition of external locations pointing
to the root of a storage account, addressing issue
[#3505](#3505). The
`access.py` file within the AWS module has also been updated,
introducing a new `path` variable and updating a for loop condition to
accurately identify missing paths in external locations referencing the
root of a storage account. New unit tests have been added to
`tests/unit/aws/test_access.py`, including a
`test_uc_roles_create_all_roles` method that checks the creation of all
possible UC roles when none exist and external locations with and
without folders. Additionally, the `backend` fixture has been updated to
include a new external location `s3://BUCKET4`, and various tests have
been updated to incorporate this location and handle errors
appropriately.
* Added assert to make sure installation is finished before
re-installation
([#3546](#3546)). In this
release, we have added an assertion to ensure that the installation
process is completed before attempting to reinstall, addressing a
previous issue where the reinstallation was starting before the first
installation was finished, causing a warning to not be raised and
resulting in a test failure. We have introduced a new function
`wait_for_installation_to_finish()`, which retries loading the
installation if it is not found, with a timeout of 2 minutes. This
function is utilized in the `test_compare_remote_local_install_versions`
test to ensure that the installation is finished before proceeding.
Furthermore, we have extracted the warning message to a variable
`error_message` for better readability. This change enhances the
reliability of the installation process.
* Added dashboards to migration progress dashboard
([#3314](#3314)). This
commit introduces significant updates to the migration progress
dashboard, adding dashboards, linting resources, and modifying existing
components. The changes include a new dashboard displaying the number of
dashboards pending migration, with the data sourced from the
`ucx_catalog.multiworkspace.objects_snapshot` table. The existing
'Migration [main]' dashboard has been updated, and unit and integration
tests have been adapted accordingly. The commit also renames several SQL
files, updates the percentage UDF, grant, job, cluster, table, and
pipeline migration progress queries, and resolves linting compatibility
issues related to Unity Catalog. The changes depend on issue
[#3424](#3424), progress
issue [#3045](#3045), and
break up issue
[#3112](#3112). The new
dashboard aims to enhance the migration process and ensure a smooth
transition to the Unity Catalog.
* Added history log encoder for dashboards
([#3424](#3424)). A new
history log encoder for dashboards has been added, addressing issues
[#3368](#3368) and
[#3369](#3369), and
modifying the existing `experimental-migration-progress` workflow. This
update includes the addition of the `DashboardOwnership` class, used to
generate ownership information for dashboards, and the
`DashboardProgressEncoder` class, responsible for encoding progress data
related to dashboards. The new functionality is tested through manual,
unit, and integration testing. In the `Table` class, the
`from_table_info` and `from_historical_data` methods have been added,
allowing for the creation of `Table` instances from `TableInfo` objects
and historical data dictionaries with more flexibility and safety. The
`test_tables.py` file in the `integration/progress` directory has also
been updated to include a new test function for checking table failures.
These changes improve the tracking and management of dashboard IDs,
enhance user name retrieval, and ensure the accurate determination of
object ownership.
* Create specific failure for Python syntax error while parsing with
Astroid ([#3498](#3498)).
This commit enhances the Python linting functionality in our open-source
library by introducing a specific failure message, `python-parse-error`,
for syntax errors encountered during code parsing using Astroid.
Previously, a generic `system-error` message was used, which has been
renamed to maintain consistency with the existing `sql-parse-error`
message. This change provides clearer failure indicators and includes
more detailed information about the error location. Additionally,
modifications to Python linting-related code, unit test additions, and
updates to the README guide users on handling these new error types have
been implemented. A new method, `Tree.maybe_parse()`, has been
introduced to parse Python code and detect syntax errors, ensuring more
precise error handling for users.
* DBR 16 and later support
([#3481](#3481)). This pull
request introduces support for Databricks Runtime (DBR) 16 and later in
the code that converts Hive Metastore (HMS) tables to external tables
within the `migrate-tables` workflow. The changes include the addition
of a new static method `_get_entity_storage_locations` to handle the new
`entityStorageLocations` property in DBR16 and the modification of the
`_convert_hms_table_to_external` method to account for this property.
Additionally, the `run_workflow` function in the `assessment` workflow
now has the `skip_job_wait` parameter set to `True`, which allows the
workflow to continue running even if a job within it fails. The changes
have been manually tested for DBR16, verified in a staging environment,
and existing integration tests have been run for DBR 15. The diff also
includes updates to the
`test_table_migration_convert_manged_to_external` method to skip job
waiting during testing, enabling the test to run successfully on DBR 16.
* Delete stale code: `NotebookLinter._load_source_from_run_cell`
([#3529](#3529)). In this
update, we have removed the stale code
`NotebookLinter._load_source_from_run_cell`, which was responsible for
loading the source code from a run cell in a notebook. This change is a
part of the ongoing effort to address issue
[#3514](#3514) and enhances
the overall codebase. Additionally, we have modified the existing
`databricks labs ucx lint-local-code` command to update the code linting
functionality. We have conducted manual testing to ensure that the
changes function as intended and have added and modified several unit
tests. The `_load_source_from_run_cell` method is no longer needed, as
it was part of a deprecated functionality. The modifications to the
`databricks labs ucx lint-local-code` command impact the way code
linting is performed, ultimately improving the efficiency and
maintainability of the codebase.
* Exclude ucx dashboards from Lakeview dashboard crawler
([#3450](#3450)). In this
release, we have enhanced the `lakeview_crawler` method in the
open-source library to exclude Ucx dashboards and prevent false
positives. This has been achieved by adding a new optional argument,
`exclude_dashboard_ids`, to the `__init__` method, which takes a list of
dashboard IDs to exclude from the crawler. The `_crawl` method has been
updated to skip dashboards whose IDs match the ones in the
`exclude_dashboard_ids` list. The change includes unit tests and manual
testing to ensure proper functionality and has been verified on the
staging environment. These updates improve the accuracy and reliability
of the dashboard crawler, providing better results for software
engineers utilizing this library.
* Fixed issue in installing UCX on UC enabled workspace
([#3501](#3501)). This PR
introduces changes to the `ClusterPolicyInstaller` class, updating the
`spark_version` policy definition from a fixed value to an allowlist
with a default value. This resolves an issue where, when UC is enabled
on a workspace, the cluster definition takes on `single_user` and
`user_isolation` values instead of `Legacy_Single_User` and
'Legacy_Table_ACL'. The job definition is also updated to use the
default value when not explicitly provided. These changes improve
compatibility with UC-enabled workspaces, ensuring the correct values
for `spark_version` in the cluster definition. The PR includes updates
to unit tests and installation tests, addressing issue
[#3420](#3420).
* Fixed typo in workflow name (in error message)
([#3491](#3491)). This PR
(Pull Request) addresses a minor typo in the error message displayed by
the `validate_groups_permissions` method in the `workflows.py` file. The
typo occurred in the workflow name mentioned in the error message, where
`group` was incorrectly spelled as "groups." The corrected spelling is
now `validate-groups-permissions`. This change does not introduce any
new methods or modify any existing functionality, but instead focuses on
enhancing the clarity and accuracy of the error message. Ensuring that
error messages are free from typos and other inaccuracies is essential
for maintaining the usability and effectiveness of the code, as it
enables users to more easily troubleshoot any issues that may arise
during its usage.
* HMS Federation Glue Support
([#3526](#3526)). This
commit introduces support for HMS Federation Glue in the open-source
library, resolving issue
[#3011](#3011). The changes
include adding a new command, `migrate-glue-credentials`, to migrate
Glue credentials to UC storage credentials in the federation glue for
HMS. The `AWSResourcePermissions` class has been updated to include a
new parameter `config` for HMS Federation Glue configuration and the
`load_uc_compatible_roles` method now accepts an optional
`resource_type` parameter for filtering compatible roles based on the
provided type. Additionally, the `ExternalLocations` class has been
updated to handle S3 resource type when identifying missing external
locations. The commit also includes several bug fixes, new classes,
methods, and changes to the existing methods to handle AWS Glue
resources, and updates to the integration tests. Overall, these changes
add significant functionality for AWS Glue support in the HMS Federation
Glue feature.
* Make link to issue template url safe
([#3508](#3508)). In this
release, we have updated the `python_ast.py` file to enhance the
encoding of the link to the issue template for bug reports. By utilizing
the `urllib.parse.quote_plus()` function from Python's standard library,
we have ensured that any special characters in the provided source code
will be properly encoded. This eliminates the risk of issues arising
from incorrectly interpreted characters, enhancing the reliability of
the bug reporting process. This change, initially introduced in issue
[#3498](#3498), has been
thoroughly tested to guarantee its correct functioning. The rest of the
file remains unaffected, preserving its original functionality.
* Refactor `PipelineMigrator`'s to add `include_pipeline_ids`
([#3495](#3495)). In this
release, the `PipelineMigrator` class has been refactored to enhance
pipeline migration functionality. The `skip-pipeline-ids` flag has been
replaced with `include-pipeline-ids`, allowing users to specify a list
of pipelines to migrate, rather than listing pipelines to skip.
Additionally, the `exclude_pipeline_ids` functionality has been added to
provide even more granularity in pipeline selection. The
`migrate_pipelines` method now prioritizes `include_pipeline_ids` and
`exclude_pipeline_ids` parameters to determine the list of pipelines for
migration. The `_migrate_pipeline` method has been updated to accept a
string pipeline ID and now checks if the pipeline has already been
migrated. Several support methods, such as `_clone_pipeline`, have also
been refactored for improved functionality. Although no new methods were
added, the behavior of the `migrate_pipelines` method has changed. While
unit tests have been updated to cover the changes, integration tests
have not been modified yet. Ensure thorough testing to prevent any new
issues or breaks in existing functionality.
* Release v0.54.0
([#3530](#3530)). 0.54.0
brings several enhancements and bug fixes to the UCX library. A
`query_statement_disposition` option is added to the SQL backend to
handle large SQL queries during assessment results export, preventing
potential failures in large workspaces with high volumes of findings.
AWS role compatibility checks are improved for external locations
pointing to the root of a storage account. Dashboards are enhanced with
added migration progress dashboards and a history log encoder. New
failure types are introduced for Python syntax errors during parsing and
SQL parsing errors. The library now supports DBR 16 and later versions,
with optional conversion of Hive Metastore tables to external tables in
the `migrate-tables` workflow. The `PipelineMigrator` functionality is
refactored to add an `include_pipeline_ids` parameter for better control
over the migration process. Various dependency updates, including
`databricks-labs-blueprint`, `databricks-sdk`, and `sqlglot`, are
included in this release, which bring new features, improvements, and
bug fixes, as well as API changes. Please thoroughly test and review the
changes to ensure seamless functionality.
* Rename Python AST's `Tree` methods for clarity
([#3524](#3524)). In this
release, we have made significant improvements to the clarity of the
Python AST's `Tree` methods in the `python_analyzer.py` file. The
`append_` and `extend_` methods have been renamed to `attach_` to better
reflect their functionality. These methods now always return `None`. New
methods such as `attach_child_tree`, `attach_nodes`, and
`extend_globals` have been introduced to enhance the functionality of
the library. The `attach_child_tree` method allows for attaching one
tree as a child of another tree, propagating module references and
enabling traversal from both the parent and child trees. The
`attach_nodes` method sets the parent of the attached nodes and adds
them to the body of the tree. Additionally, docstrings have been added,
and unit testing has been expanded. The changes include modifications to
code linting, existing command functionalities, and manual testing to
ensure compatibility. These enhancements improve the clarity,
functionality, and flexibility of the Python AST's `Tree` methods.
* Revert "Release v0.54.0"
([#3569](#3569)). In version
0.53.1, we have reverted changes from 0.54.0 to address issues with the
previous release and ensure proper propagation to PyPI. This version
includes various updates such as implementing a disposition field in the
SQL backend, improving ARN pattern matching for AWS roles, adding
dashboards to migration progress, enhancing Python linting
functionality, and adding support for DBR 16 in converting Hive
Metastore tables to external tables. We have also excluded UCX
dashboards from the Lakeview dashboard crawler, refactored
PipelineMigrator's to add include_pipeline_ids, and updated the sqlglot
and databricks-labs-blueprint requirements. Additionally, several issues
related to installation, typo in workflow name, and table-migration
workflows have been fixed. The sqlglot requirement has been updated from
<26.1,>=25.5.0 to >=25.5.0,<26.2, and databricks-labs-blueprint from
<0.10,>=0.9.1 to >=0.9.1,<0.11. This release does not introduce any new
methods or change existing functionality, but focuses on addressing bugs
and improving functionality.
* Schedule the migration progress workflow to run daily
([#3485](#3485)). This PR
introduces a daily scheduling mechanism for the UCX installation's
migration progress workflow, allowing it to run automatically once per
day at 5 a.m. UTC. It includes refactoring the plumbing for managing and
installing workflows, enabling them to have a Cron-based schedule.
Relevant user documentation has been updated, and existing unit and
integration tests have been added to ensure the changes function as
intended. A new test has been added to verify the migration-progress
workflow is installed with a schedule attached, checking the workflow
schedule's quartz cron expression, time zone, and pause status, as well
as confirming that the workflow is unpaused upon installation. The PR
also introduces new methods to manage workflow scheduling and configure
cron-based schedules.
* Scope crawled pipelines in PipelineCrawler
([#3513](#3513)). In the
latest release, we have introduced a new optional argument,
'include_pipeline_ids', in the constructor of the PipelinesCrawler class
located in the 'databricks/labs/ucx/assessment' module. This argument
allows users to filter pipelines based on a list of pipeline IDs,
improving the crawler's flexibility and efficiency in processing
pipelines. In the `_crawl` method of the PipelinesCrawler class, a new
behavior has been implemented based on the value of
'include_pipeline_ids'. If the argument is not None, then the method
uses the pipeline IDs from this list instead of retrieving all
pipelines. Additionally, two unit tests have been added to verify the
functionality of this new argument and ensure that the crawler handles
cases where a pipeline is not found or its specification is missing. A
new parameter, 'force_refresh', has also been added to the `snapshot`
function. This release aims to provide a more efficient and customizable
pipeline crawling experience for users.
* Updated databricks-labs-blueprint requirement from <0.10,>=0.9.1 to
>=0.9.1,<0.11
([#3519](#3519)). In this
update, the requirement for the `databricks-labs-blueprint` library has
been changed from version range '<0.10,>=0.9.1>' to a new range of
'>=0.9.1,<0.11'. This change allows for the use of the latest version of
the library while maintaining compatibility with the current project
setup, and is based on information from the library's releases and
changelog. The commit includes a list of commits and dependencies for
the updated library. This update was automatically implemented by
Dependabot, a tool that handles dependency updates and conflict
resolution, ensuring a seamless integration process for engineers
adopting the project.
* Updated databricks-sdk requirement from <0.41,>=0.40 to >=0.40,<0.42
([#3553](#3553)). In this
release, we have updated the `databricks-sdk` package requirement to
permit version 0.41 while excluding version 0.42. This update includes
several improvements and new features in version 0.41, such as the
addition of the `serving.http_request` method for calling external
functions and enhancements to the Files API client to recover from
download failures. The commit also includes bug fixes, internal changes,
and updates to the API for better functionality and compatibility. It is
essential to note that these changes have been made to ensure
compatibility with the latest features and improvements in the
`databricks-sdk` package.
* Updated sqlglot requirement from <26.1,>=25.5.0 to >=25.5.0,<26.2
([#3500](#3500)). In this
release, we have updated the version requirement for the sqlglot
package. The minimum version required is now 25.5.0 and less than 26.2,
previously it was 25.5.0 and less than 26.1. This change allows for the
most recent version of sqlglot to be installed, while still maintaining
compatibility with the current codebase. The update is necessary due to
breaking changes introduced in version 26.1.0 of sqlglot, including
normalizing before qualifying tables, requiring the `AS` token in CTEs
for all dialects except spark and databricks, supporting Unicode in
sqlite, mysql, tsql, postgres, and oracle, parsing ASCII into Unicode to
facilitate transpilation, and improving transpilation of
CHAR[ACTER]_LENGTH. Additionally, several bug fixes and new features
have been added in this update.
* Updated sqlglot requirement from <26.2,>=25.5.0 to >=25.5.0,<26.3
([#3528](#3528)). In this
release, we have updated the version constraint for the `sqlglot`
dependency in our project's "pyproject.toml" file. The previous
constraint allowed versions between 25.5.0 and 26.2, while the new
constraint allows versions between 25.5.0 and 26.3. This change was made
to ensure that we can use the latest version of sqlglot while also
preventing the version from exceeding 26.3. Additionally, the commit
includes detailed information about the specific commits and changes
made in the updated version of sqlglot, providing valuable insights for
software engineers working with this open-source library.
* Updated table-migration workflows to also capture updated migration
progress into the history log
([#3239](#3239)). The
table-migration workflows have been updated to log not only the tables
that still need to be migrated, but also the updated progress
information into the history log, ensuring a more comprehensive record
of migration progress. The affected workflows include `migrate-tables`,
`migrate-external-hiveserde-tables-in-place-experimental`,
`migrate-external-tables-ctas`, `scan-tables-in-mounts-experimental`,
and `migrate-tables-in-mounts-experimental`. The encoder for
table-history has been updated to prevent implicit refresh of
`TableMigrationStatus` data during initialization. Additionally, the
documentation has been updated to reflect which workflows update which
tables. New and updated unit and integration tests, as well as manual
testing, have been conducted to ensure the functionality of the changes.

Dependency updates:

* Updated sqlglot requirement from <26.1,>=25.5.0 to >=25.5.0,<26.2
([#3500](#3500)).
* Updated databricks-labs-blueprint requirement from <0.10,>=0.9.1 to
>=0.9.1,<0.11
([#3519](#3519)).
* Updated databricks-sdk requirement from <0.41,>=0.40 to >=0.40,<0.42
([#3553](#3553)).
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
migrate/code Abstract Syntax Trees and other dark magic
Projects
Status: Done
Development

Successfully merging this pull request may close these issues.

2 participants