v0.2.4
- Fixed
Builder
object is not callable error (#67). In this release, we have made an enhancement to theBackends
class in thedatabricks/labs/lsql/backends.py
file. TheDatabricksSession.builder()
method call in the__init__
method has been changed toDatabricksSession.builder
. This update uses thebuilder
attribute to create a new instance ofDatabricksSession
without calling it like a function. Thesdk_config
method is then used to configure the instance with the required settings. Finally, thegetOrCreate
method is utilized to obtain aSparkSession
object, which is then passed as a parameter to the parent class constructor. This modification simplifies the code and eliminates the error caused by treating thebuilder
attribute as a callable object. Software engineers may benefit from this change by having a more streamlined and error-free codebase when working with the open-source library. - Prevent silencing of
pylint
(#65). In this release, we have introduced a new job, "no-lint-disabled", to the GitHub Actions workflow for the repository. This job runs on the latest Ubuntu version and checks out the codebase with a full history. It verifies that no new instances of code suppressingpylint
checks have been added, by filtering the differences between the current branch and the main branch for new lines of code, and then checking if any of those new lines contain apylint
disable comment. If any such lines are found, the job will fail and print a message indicating the offending lines of code, thereby ensuring that the codebase maintains a consistent level of quality by not allowing linting checks to be bypassed. - Updated
_SparkBackend.fetch()
to return iterator instead of list (#62). In this release, thefetch()
method of the_SparkBackend
class has been updated to return an iterator instead of a list, which can result in reduced memory usage and improved performance, as the results of the SQL query can now be processed one element at a time. A new exception has been introduced to wrap any exceptions that occur during query execution, providing better debugging and error handling capabilities. Thetest_runtime_backend_fetch()
unit test has been updated to reflect this change, and users of thefetch()
method should be aware that it now returns an iterator and must be consumed to obtain the desired data. Thorough testing is recommended to ensure that the updated method still meets the needs of the application.
Contributors: @nfx, @qziyuan, @bishwajit-db