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

Extension Updating #11677

Merged
merged 62 commits into from
May 21, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
62 commits
Select commit Hold shift + click to select a range
d783f00
add syntax to install a versioned extension
samansmink Jan 2, 2024
867547a
fixes to extension versioned install
samansmink Feb 2, 2024
b8657dc
duplicate header
samansmink Feb 2, 2024
d55942b
basic idea of extension updating working
samansmink Mar 6, 2024
445d9b1
extension updating + small refactor
samansmink Mar 7, 2024
308bc10
Merge branch 'main' into install-extension-version
samansmink Apr 3, 2024
22a0b33
Merge branch 'extension_metadata' into install-extension-version-merged
samansmink Apr 10, 2024
0d22196
add repository aliasing
samansmink Apr 10, 2024
c6e0337
rework extension repository mechanism slightly
samansmink Apr 10, 2024
1f0386b
more extension updating improvements
samansmink Apr 15, 2024
5059c5b
switch to dedicated opeator for update extensions
samansmink Apr 15, 2024
228ebc2
add CI test for succesful update extensions statement
samansmink Apr 15, 2024
1de4405
format
samansmink Apr 15, 2024
f00322b
some minor extension updating fixes
samansmink Apr 15, 2024
f775594
remove old test
samansmink Apr 15, 2024
2f294b1
add errors to incorrect version installation as well
samansmink Apr 16, 2024
5cd6002
format
samansmink Apr 16, 2024
6f1bde6
improve extension versioning/updating CI
samansmink Apr 16, 2024
70d416d
disable broken test for now
samansmink Apr 16, 2024
c6082bc
fix broken test
samansmink Apr 16, 2024
96e5ff8
remove old code
samansmink Apr 16, 2024
36299a8
Merge branch 'main' into install-extension-version-merged
samansmink Apr 16, 2024
96f8922
Extension API: Add optional member Version()
carlopi Apr 16, 2024
2a55929
Use ext.Version() to handle versioning info also for built-in extensions
carlopi Apr 16, 2024
c32e54e
CMake: Propagate EXT_VERSION_NAME to hold the CMake computed version …
carlopi Apr 16, 2024
ae5d3eb
In-tree extensions to be passed the versioning info
carlopi Apr 16, 2024
7099214
forward define for python
samansmink Apr 17, 2024
f8a4dac
re-enable test assertion
samansmink Apr 17, 2024
21f5e7e
small CI fixes
samansmink Apr 17, 2024
4f0088a
wip
samansmink Apr 19, 2024
f4d0597
Merge branch 'main' into install-extension-version-merged
samansmink May 10, 2024
5f12217
fix merge conflict issue
samansmink May 10, 2024
df7c860
add accidentally removed cast
samansmink May 13, 2024
4cf2ccb
Merge branch 'main' into install-extension-version-merged
samansmink May 13, 2024
4bcc31e
cleanup changes to extension updating
samansmink May 13, 2024
7d684db
fixing ci for extension update PR
samansmink May 13, 2024
99f87da
add extension version detection
samansmink May 13, 2024
7ba67d3
fix out-of-tree version-detection
samansmink May 14, 2024
5bb8b50
dont set EXT_VERSION_ define if no version is available
samansmink May 14, 2024
09a19cd
add auto-loading for extension install over httpfs
samansmink May 14, 2024
8efd4a5
format
samansmink May 14, 2024
1e8ebdd
fix install gzipped from https urls
samansmink May 15, 2024
9c26dc2
better error handling for malformed or missing info files
samansmink May 15, 2024
9422b49
small tweak to extension install write order
samansmink May 16, 2024
18d0edb
switch to explicit difference between repo and repo url
samansmink May 16, 2024
ee1c21e
add test cases for malformed and missing info files
samansmink May 16, 2024
4aefceb
add gzipped extension install to non-http install
samansmink May 16, 2024
b3c471f
add http tests as well
samansmink May 16, 2024
cc77eec
fix ci issue and fix updating over https issue
samansmink May 16, 2024
76acf25
fix extension updating job
samansmink May 16, 2024
c510994
build with tpch
samansmink May 16, 2024
8f484a5
clang tidy, speed up decompress
samansmink May 17, 2024
e0b4e89
small extension updating fixes
samansmink May 17, 2024
3ae45d6
format
samansmink May 17, 2024
1736368
several smaller fixes to extension installation and updating
samansmink May 17, 2024
cdb1c4d
catch install without force from different repo
samansmink May 17, 2024
52ebf66
fix memory leak on exceptions in listfiles
samansmink May 17, 2024
d02f157
format
samansmink May 17, 2024
0ed81d0
add no_extension_autoloading
samansmink May 18, 2024
529759a
Merge branch 'main' into install-extension-version-merged
samansmink May 19, 2024
d14607e
fix generated_extensions script to handle csv format instead of txt f…
samansmink May 19, 2024
b530912
small ci fixes
samansmink May 20, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
some minor extension updating fixes
  • Loading branch information
samansmink committed Apr 15, 2024
commit f00322b7caa759708a2c6dfd92066d1ac39f5ad0
2 changes: 0 additions & 2 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -307,8 +307,6 @@ else()
set(DUCKDB_VERSION "v${DUCKDB_MAJOR_VERSION}.${DUCKDB_MINOR_VERSION}.${DUCKDB_PATCH_VERSION}-dev${DUCKDB_DEV_ITERATION}")
endif()

set(DUCKDB_VERSION "v0.10.0")

string(REGEX MATCH ".*dev.*" DUCKDB_EXTENSION_FOLDER_IS_VERSION "${DUCKDB_VERSION}")

if(DUCKDB_EXTENSION_FOLDER_IS_VERSION AND NOT GIT_COMMIT_HASH STREQUAL "")
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,6 @@ unique_ptr<GlobalSourceState> PhysicalUpdateExtensions::GetGlobalSourceState(Cli
res->update_result_entries.emplace_back(ExtensionHelper::UpdateExtension(context, ext));
}
}
// TODO: update specific extensions;

return std::move(res);
}
Expand Down
2 changes: 0 additions & 2 deletions src/include/duckdb/main/extension_install_info.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -25,8 +25,6 @@ class ExtensionInstallInfo {
ExtensionInstallMode mode;
//! Full path where the extension was generated from
string full_path;
//! This extension was installed at an explicit version, it will not be updated
bool pinned_version = false;
//! (optional) Repository url where the extension came from
string repository_url;
//! (optional) Version of the extension
Expand Down
11 changes: 6 additions & 5 deletions src/main/extension/extension_helper.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -222,7 +222,7 @@ bool ExtensionHelper::TryAutoLoadExtension(ClientContext &context, const string
}
}

static ExtensionUpdateResult update_extension(DBConfig &config, FileSystem &fs, const string &full_extension_path,
static ExtensionUpdateResult UpdateExtensionInternal(DBConfig &config, FileSystem &fs, const string &full_extension_path,
const string &extension_name) {
ExtensionUpdateResult result;
result.extension_name = extension_name;
Expand All @@ -241,8 +241,9 @@ static ExtensionUpdateResult update_extension(DBConfig &config, FileSystem &fs,
if (!parsed_metadata.AppearsValid() && !config.options.allow_extensions_metadata_mismatch) {
throw IOException(
"Failed to update extension: '%s', the metadata of the extension appears invalid! To resolve this, either "
"manually remove the file '%s' or enable 'allow_extensions_metadata_mismatch' and rerun this command",
extension_name, full_extension_path);
"reinstall the extension using 'FORCE INSTALL %s', manually remove the file '%s', or enable '"
"SET allow_extensions_metadata_mismatch=true'",
extension_name, extension_name, full_extension_path);
}

result.prev_version = parsed_metadata.AppearsValid() ? parsed_metadata.extension_version : "";
Expand Down Expand Up @@ -307,7 +308,7 @@ vector<ExtensionUpdateResult> ExtensionHelper::UpdateExtensions(DBConfig &config
auto extension_file_name = StringUtil::GetFileName(path);
auto extension_name = StringUtil::Split(extension_file_name, ".")[0];

result.push_back(update_extension(config, fs, fs.JoinPath(ext_directory, path), extension_name));
result.push_back(UpdateExtensionInternal(config, fs, fs.JoinPath(ext_directory, path), extension_name));
});
#endif

Expand All @@ -324,7 +325,7 @@ ExtensionUpdateResult ExtensionHelper::UpdateExtension(DBConfig &config, FileSys

auto full_extension_path = fs.JoinPath(ext_directory, extension_name + ".duckdb_extension");

auto update_result = update_extension(config, fs, full_extension_path, extension_name);
auto update_result = UpdateExtensionInternal(config, fs, full_extension_path, extension_name);

if (update_result.tag == ExtensionUpdateResultTag::NOT_INSTALLED) {
throw InvalidInputException("Failed to update the extension '%s', the extension is not installed!",
Expand Down
32 changes: 19 additions & 13 deletions src/main/extension/extension_load.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -120,9 +120,8 @@ ParsedExtensionMetaData ExtensionHelper::ParseExtensionMetaData(FileHandle &hand

if (handle.GetFileSize() < ParsedExtensionMetaData::FOOTER_SIZE) {
throw InvalidInputException(
"Extension \"%s\" do not have metadata compatible with DuckDB loading it "
"(version %s, platform %s). File size in particular is lower than minimum threshold of 1024",
handle.path, engine_version, engine_platform);
"File '%s' is not a DuckDB extension. Valid DuckDB extensions must be at least %llu bytes",
handle.path, ParsedExtensionMetaData::FOOTER_SIZE);
}

handle.Read((void *)metadata_segment.data(), metadata_segment.size(),
Expand Down Expand Up @@ -258,18 +257,25 @@ bool ExtensionHelper::TryInitialLoad(DBConfig &config, FileSystem &fs, const str
// Check the parsed
if (!parsed_metadata.AppearsValid()) {
// metadata do not looks right, add this to the error message
metadata_mismatch_error =
"\n" + StringUtil::Format("Extension \"%s\" do not have metadata compatible with DuckDB "
"loading it (version %s, platform %s)",
handle->path, engine_version, engine_platform);
} else if (engine_version != parsed_metadata.duckdb_version || engine_platform != parsed_metadata.platform) {
metadata_mismatch_error =
"\n" + StringUtil::Format("Extension \"%s\" (version %s, platfrom %s) does not "
"match DuckDB loading it (version %s, platform %s)",
handle->path, PrettyPrintString(parsed_metadata.duckdb_version),
PrettyPrintString(parsed_metadata.platform), engine_version, engine_platform);
metadata_mismatch_error = StringUtil::Format("\nFile '%s' is not a DuckDB extension. The metadata at the end of the file is invalid. "
"This version of DuckDB can only load extensions that are compiled for DuckDB "
"version '%s', platform '%s'.", handle->path, engine_version, engine_platform);
} else if (engine_version != parsed_metadata.duckdb_version || engine_platform != parsed_metadata.platform) {
metadata_mismatch_error = StringUtil::Format("\nFile '%s' is a DuckDB extension, but the metadata does not match:", handle->path);

if (engine_version != parsed_metadata.duckdb_version) {
metadata_mismatch_error +=
"\n" + StringUtil::Format("\nThe file was built for DuckDB version '%s', but we can only load extensions built for DuckDB version '%s'.",
PrettyPrintString(parsed_metadata.duckdb_version), engine_version);
}
if (engine_platform != parsed_metadata.platform) {
metadata_mismatch_error +=
"\n" + StringUtil::Format("\nThe file was built for the platform '%s', but we can only load extensions built for platform '%s'.",
PrettyPrintString(parsed_metadata.platform), engine_platform);
}
}


if (!config.options.allow_unsigned_extensions) {
bool signature_valid = CheckExtensionSignature(*handle, parsed_metadata);

Expand Down