From 53b7b5d6d40b21b3d2b9261ca44ad8d47d684f9b Mon Sep 17 00:00:00 2001 From: ryfu-msft Date: Tue, 22 Oct 2024 10:02:30 -0700 Subject: [PATCH 1/2] Revert "Change meaning of AddOrUpdate return bool (#4885)" This reverts commit 3be2ba0f1fd7ad5304f502e5ad2ca28b88fc0b67. --- src/AppInstallerCLITests/SQLiteIndex.cpp | 8 ++++---- src/AppInstallerRepositoryCore/Microsoft/SQLiteIndex.cpp | 3 +-- src/AppInstallerRepositoryCore/Microsoft/SQLiteIndex.h | 6 +++--- src/WinGetUtil/WinGetUtil.h | 2 +- .../APIUnitTests/SQLiteIndexUnitTests.cs | 8 ++++---- src/WinGetUtilInterop/Interfaces/IWinGetSQLiteIndex.cs | 2 +- 6 files changed, 14 insertions(+), 15 deletions(-) diff --git a/src/AppInstallerCLITests/SQLiteIndex.cpp b/src/AppInstallerCLITests/SQLiteIndex.cpp index fb381ebb72..defb5bc206 100644 --- a/src/AppInstallerCLITests/SQLiteIndex.cpp +++ b/src/AppInstallerCLITests/SQLiteIndex.cpp @@ -3918,20 +3918,20 @@ TEST_CASE("SQLiteIndex_AddOrUpdateManifest", "[sqliteindex]") { SQLiteIndex index = SQLiteIndex::Open(tempFile, SQLiteStorageBase::OpenDisposition::ReadWrite); - // Update should return false + // Update with no updates should return false REQUIRE(!index.AddOrUpdateManifest(manifest, manifestPath)); manifest.DefaultLocalization.Add("description2"); - // Update should return false + // Update with no indexed updates should return false REQUIRE(!index.AddOrUpdateManifest(manifest, manifestPath)); - // Update with indexed changes should still return false + // Update with indexed changes manifest.DefaultLocalization.Add("Test Name2"); manifest.Moniker = "testmoniker2"; manifest.DefaultLocalization.Add({ "t1", "t2", "t3" }); manifest.Installers[0].Commands = {}; - REQUIRE(!index.AddOrUpdateManifest(manifest, manifestPath)); + REQUIRE(index.AddOrUpdateManifest(manifest, manifestPath)); } } diff --git a/src/AppInstallerRepositoryCore/Microsoft/SQLiteIndex.cpp b/src/AppInstallerRepositoryCore/Microsoft/SQLiteIndex.cpp index ba4c089158..bbd3305d81 100644 --- a/src/AppInstallerRepositoryCore/Microsoft/SQLiteIndex.cpp +++ b/src/AppInstallerRepositoryCore/Microsoft/SQLiteIndex.cpp @@ -194,8 +194,7 @@ namespace AppInstaller::Repository::Microsoft if (m_interface->GetManifestIdByManifest(m_dbconn, manifest)) { - UpdateManifestInternalHoldingLock(manifest, relativePath); - return false; + return UpdateManifestInternalHoldingLock(manifest, relativePath); } else { diff --git a/src/AppInstallerRepositoryCore/Microsoft/SQLiteIndex.h b/src/AppInstallerRepositoryCore/Microsoft/SQLiteIndex.h index 6dc3cac54e..e60262800b 100644 --- a/src/AppInstallerRepositoryCore/Microsoft/SQLiteIndex.h +++ b/src/AppInstallerRepositoryCore/Microsoft/SQLiteIndex.h @@ -95,15 +95,15 @@ namespace AppInstaller::Repository::Microsoft bool UpdateManifest(const Manifest::Manifest& manifest); // Adds or updates the manifest with matching { Id, Version, Channel } in the index. - // The return value indicates whether the manifest was added (true) or updated (false). + // The return value indicates whether the index was modified by the function. bool AddOrUpdateManifest(const std::filesystem::path& manifestPath, const std::filesystem::path& relativePath); // Updates the manifest with matching { Id, Version, Channel } in the index. - // The return value indicates whether the manifest was added (true) or updated (false). + // The return value indicates whether the index was modified by the function. bool AddOrUpdateManifest(const Manifest::Manifest& manifest, const std::filesystem::path& relativePath); // Updates the manifest with matching { Id, Version, Channel } in the index. - // The return value indicates whether the manifest was added (true) or updated (false). + // The return value indicates whether the index was modified by the function. bool AddOrUpdateManifest(const Manifest::Manifest& manifest); // Removes the manifest with matching { Id, Version, Channel } from the index. diff --git a/src/WinGetUtil/WinGetUtil.h b/src/WinGetUtil/WinGetUtil.h index fe60ca77ed..86a69f1c04 100644 --- a/src/WinGetUtil/WinGetUtil.h +++ b/src/WinGetUtil/WinGetUtil.h @@ -159,7 +159,7 @@ extern "C" BOOL* indexModified); // Adds or Updates the manifest with matching { Id, Version, Channel } in the index. - // The return value indicates whether the manifest was added (true) or updated (false). + // The return value indicates whether the index was modified by the function. WINGET_UTIL_API WinGetSQLiteIndexAddOrUpdateManifest( WINGET_SQLITE_INDEX_HANDLE index, WINGET_STRING manifestPath, diff --git a/src/WinGetUtilInterop.UnitTests/APIUnitTests/SQLiteIndexUnitTests.cs b/src/WinGetUtilInterop.UnitTests/APIUnitTests/SQLiteIndexUnitTests.cs index 929562737b..d2ae335ac4 100644 --- a/src/WinGetUtilInterop.UnitTests/APIUnitTests/SQLiteIndexUnitTests.cs +++ b/src/WinGetUtilInterop.UnitTests/APIUnitTests/SQLiteIndexUnitTests.cs @@ -188,13 +188,13 @@ public void AddOrUpdateManifest() { this.CreateIndexHelperForIndexTest((wrapper) => { - // Add manifest; should return true. + // Add manifest. string addManifest = Path.Combine(this.indexTestDataPath, PackageTest); - Assert.True(wrapper.AddOrUpdateManifest(addManifest, PackageTestRelativePath)); + wrapper.AddOrUpdateManifest(addManifest, PackageTestRelativePath); - // Update manifest. name is different, should return false. + // Update manifest. name is different, should return true. string updateManifest = Path.Combine(this.indexTestDataPath, PackageTestNewName); - Assert.False(wrapper.AddOrUpdateManifest(updateManifest, PackageTestRelativePath)); + Assert.True(wrapper.AddOrUpdateManifest(updateManifest, PackageTestRelativePath)); return true; }); diff --git a/src/WinGetUtilInterop/Interfaces/IWinGetSQLiteIndex.cs b/src/WinGetUtilInterop/Interfaces/IWinGetSQLiteIndex.cs index 15c1e30d6f..96a5661765 100644 --- a/src/WinGetUtilInterop/Interfaces/IWinGetSQLiteIndex.cs +++ b/src/WinGetUtilInterop/Interfaces/IWinGetSQLiteIndex.cs @@ -67,7 +67,7 @@ public interface IWinGetSQLiteIndex : IDisposable /// /// Path to manifest. /// Path of the manifest in the repository. - /// True if added; false if updated. + /// True if index was modified. bool AddOrUpdateManifest(string manifestPath, string relativePath); /// From 6097e96fab36bbeafb45154547fe2fbde29ab480 Mon Sep 17 00:00:00 2001 From: ryfu-msft Date: Tue, 22 Oct 2024 10:02:47 -0700 Subject: [PATCH 2/2] Revert "Make adding overlapping ARP range a hard error (#4870)" This reverts commit 2e4c2763c8fd1674b3b3bc55850dac598ce0077c. --- src/AppInstallerCLITests/SQLiteIndex.cpp | 83 +----------------- .../Microsoft/SQLiteIndex.cpp | 44 ---------- .../Microsoft/SQLiteIndex.h | 15 ---- .../Microsoft/Schema/1_5/Interface.h | 7 +- .../Microsoft/Schema/1_5/Interface_1_5.cpp | 86 ++++--------------- src/WinGetUtil/Exports.cpp | 20 ----- src/WinGetUtil/Source.def | 1 - src/WinGetUtil/WinGetUtil.h | 8 -- .../APIUnitTests/SQLiteIndexUnitTests.cs | 23 +---- .../Api/WinGetSQLiteIndex.cs | 37 -------- .../Interfaces/IWinGetSQLiteIndex.cs | 8 -- 11 files changed, 22 insertions(+), 310 deletions(-) diff --git a/src/AppInstallerCLITests/SQLiteIndex.cpp b/src/AppInstallerCLITests/SQLiteIndex.cpp index defb5bc206..97589be506 100644 --- a/src/AppInstallerCLITests/SQLiteIndex.cpp +++ b/src/AppInstallerCLITests/SQLiteIndex.cpp @@ -3241,7 +3241,7 @@ TEST_CASE("SQLiteIndex_RemoveManifestArpVersionKeepUsedDeleteUnused", "[sqlitein } } -TEST_CASE("SQLiteIndex_ManifestArpVersionConflict_AddThrows", "[sqliteindex]") +TEST_CASE("SQLiteIndex_ManifestArpVersion_CheckConsistency", "[sqliteindex]") { TempFile tempFile{ "repolibtest_tempdb"s, ".db"s }; INFO("Using temporary file named: " << tempFile.GetPath()); @@ -3267,44 +3267,9 @@ TEST_CASE("SQLiteIndex_ManifestArpVersionConflict_AddThrows", "[sqliteindex]") // Add a conflicting one manifest.Version = "10.1"; - REQUIRE_THROWS_HR(index.AddManifest(manifest, "path2"), APPINSTALLER_CLI_ERROR_ARP_VERSION_VALIDATION_FAILED); -} - -TEST_CASE("SQLiteIndex_ManifestArpVersionConflict_UpdateThrows", "[sqliteindex]") -{ - TempFile tempFile{ "repolibtest_tempdb"s, ".db"s }; - INFO("Using temporary file named: " << tempFile.GetPath()); - - SQLiteIndex index = CreateTestIndex(tempFile, SQLiteVersion::Latest()); - - Manifest manifest; - manifest.Id = "Foo"; - manifest.Version = "10.0"; - manifest.DefaultLocalization.Add("ArpVersionCheckConsistencyTest"); - manifest.Moniker = "testmoniker"; - manifest.Installers.push_back({}); - manifest.Installers[0].BaseInstallerType = InstallerTypeEnum::Exe; - manifest.Installers[0].AppsAndFeaturesEntries.push_back({}); - manifest.Installers[0].AppsAndFeaturesEntries[0].DisplayVersion = "1.0"; - manifest.Installers[0].AppsAndFeaturesEntries.push_back({}); - manifest.Installers[0].AppsAndFeaturesEntries[1].DisplayVersion = "1.1"; - - index.AddManifest(manifest, "path"); - REQUIRE(index.CheckConsistency(true)); - - // Add another version - manifest.Version = "10.1"; - manifest.Installers[0].AppsAndFeaturesEntries[0].DisplayVersion = "2.0"; - manifest.Installers[0].AppsAndFeaturesEntries[1].DisplayVersion = "2.1"; - index.AddManifest(manifest, "path2"); - REQUIRE(index.CheckConsistency(true)); - // Update to a conflict - manifest.Installers[0].AppsAndFeaturesEntries[0].DisplayVersion = "1.0"; - manifest.Installers[0].AppsAndFeaturesEntries[1].DisplayVersion = "2.1"; - - REQUIRE_THROWS_HR(index.UpdateManifest(manifest, "path2"), APPINSTALLER_CLI_ERROR_ARP_VERSION_VALIDATION_FAILED); + REQUIRE_FALSE(index.CheckConsistency(true)); } TEST_CASE("SQLiteIndex_ManifestArpVersion_ValidateManifestAgainstIndex", "[sqliteindex]") @@ -3891,47 +3856,3 @@ TEST_CASE("SQLiteIndex_DependencyWithCaseMismatch", "[sqliteindex][V1_4]") index.AddManifest(manifest, GetPathFromManifest(manifest)); } - -TEST_CASE("SQLiteIndex_AddOrUpdateManifest", "[sqliteindex]") -{ - TempFile tempFile{ "repolibtest_tempdb"s, ".db"s }; - INFO("Using temporary file named: " << tempFile.GetPath()); - - std::string manifestPath = "test/id/test.id-1.0.0.yaml"; - Manifest manifest; - manifest.Installers.push_back({}); - manifest.Id = "test.id"; - manifest.DefaultLocalization.Add < Localization::PackageName>("Test Name"); - manifest.Moniker = "testmoniker"; - manifest.Version = "1.0.0"; - manifest.Channel = "test"; - manifest.DefaultLocalization.Add({ "t1", "t2" }); - manifest.Installers[0].Commands = { "test1", "test2" }; - - { - auto version = GENERATE(SQLiteVersion{ 1, 0 }, SQLiteVersion::Latest()); - SQLiteIndex index = SQLiteIndex::CreateNew(tempFile, version); - - REQUIRE(index.AddOrUpdateManifest(manifest, manifestPath)); - } - - { - SQLiteIndex index = SQLiteIndex::Open(tempFile, SQLiteStorageBase::OpenDisposition::ReadWrite); - - // Update with no updates should return false - REQUIRE(!index.AddOrUpdateManifest(manifest, manifestPath)); - - manifest.DefaultLocalization.Add("description2"); - - // Update with no indexed updates should return false - REQUIRE(!index.AddOrUpdateManifest(manifest, manifestPath)); - - // Update with indexed changes - manifest.DefaultLocalization.Add("Test Name2"); - manifest.Moniker = "testmoniker2"; - manifest.DefaultLocalization.Add({ "t1", "t2", "t3" }); - manifest.Installers[0].Commands = {}; - - REQUIRE(index.AddOrUpdateManifest(manifest, manifestPath)); - } -} diff --git a/src/AppInstallerRepositoryCore/Microsoft/SQLiteIndex.cpp b/src/AppInstallerRepositoryCore/Microsoft/SQLiteIndex.cpp index bbd3305d81..e9cc717bc3 100644 --- a/src/AppInstallerRepositoryCore/Microsoft/SQLiteIndex.cpp +++ b/src/AppInstallerRepositoryCore/Microsoft/SQLiteIndex.cpp @@ -109,11 +109,6 @@ namespace AppInstaller::Repository::Microsoft SQLiteIndex::IdType SQLiteIndex::AddManifestInternal(const Manifest::Manifest& manifest, const std::optional& relativePath) { std::lock_guard lockInterface{ *m_interfaceLock }; - return AddManifestInternalHoldingLock(manifest, relativePath); - } - - SQLiteIndex::IdType SQLiteIndex::AddManifestInternalHoldingLock(const Manifest::Manifest& manifest, const std::optional& relativePath) - { AICLI_LOG(Repo, Verbose, << "Adding manifest for [" << manifest.Id << ", " << manifest.Version << "] at relative path [" << relativePath.value_or("") << "]"); SQLite::Savepoint savepoint = SQLite::Savepoint::Create(m_dbconn, "sqliteindex_addmanifest"); @@ -148,11 +143,6 @@ namespace AppInstaller::Repository::Microsoft bool SQLiteIndex::UpdateManifestInternal(const Manifest::Manifest& manifest, const std::optional& relativePath) { std::lock_guard lockInterface{ *m_interfaceLock }; - return UpdateManifestInternalHoldingLock(manifest, relativePath); - } - - bool SQLiteIndex::UpdateManifestInternalHoldingLock(const Manifest::Manifest& manifest, const std::optional& relativePath) - { AICLI_LOG(Repo, Verbose, << "Updating manifest for [" << manifest.Id << ", " << manifest.Version << "] at relative path [" << relativePath.value_or("") << "]"); SQLite::Savepoint savepoint = SQLite::Savepoint::Create(m_dbconn, "sqliteindex_updatemanifest"); @@ -169,40 +159,6 @@ namespace AppInstaller::Repository::Microsoft return result; } - bool SQLiteIndex::AddOrUpdateManifest(const std::filesystem::path& manifestPath, const std::filesystem::path& relativePath) - { - AICLI_LOG(Repo, Verbose, << "Adding or Updating manifest from file [" << manifestPath << "]"); - - Manifest::Manifest manifest = Manifest::YamlParser::CreateFromPath(manifestPath); - return AddOrUpdateManifestInternal(manifest, relativePath); - } - - bool SQLiteIndex::AddOrUpdateManifest(const Manifest::Manifest& manifest, const std::filesystem::path& relativePath) - { - return AddOrUpdateManifestInternal(manifest, relativePath); - } - - bool SQLiteIndex::AddOrUpdateManifest(const Manifest::Manifest& manifest) - { - return AddOrUpdateManifestInternal(manifest, {}); - } - - bool SQLiteIndex::AddOrUpdateManifestInternal(const Manifest::Manifest& manifest, const std::optional& relativePath) - { - std::lock_guard lockInterface{ *m_interfaceLock }; - AICLI_LOG(Repo, Verbose, << "Adding or Updating manifest for [" << manifest.Id << ", " << manifest.Version << "] at relative path [" << relativePath.value_or("") << "]"); - - if (m_interface->GetManifestIdByManifest(m_dbconn, manifest)) - { - return UpdateManifestInternalHoldingLock(manifest, relativePath); - } - else - { - AddManifestInternalHoldingLock(manifest, relativePath); - return true; - } - } - void SQLiteIndex::RemoveManifest(const std::filesystem::path& manifestPath, const std::filesystem::path& relativePath) { AICLI_LOG(Repo, Verbose, << "Removing manifest from file [" << manifestPath << "]"); diff --git a/src/AppInstallerRepositoryCore/Microsoft/SQLiteIndex.h b/src/AppInstallerRepositoryCore/Microsoft/SQLiteIndex.h index e60262800b..6494e3b38a 100644 --- a/src/AppInstallerRepositoryCore/Microsoft/SQLiteIndex.h +++ b/src/AppInstallerRepositoryCore/Microsoft/SQLiteIndex.h @@ -94,18 +94,6 @@ namespace AppInstaller::Repository::Microsoft // The return value indicates whether the index was modified by the function. bool UpdateManifest(const Manifest::Manifest& manifest); - // Adds or updates the manifest with matching { Id, Version, Channel } in the index. - // The return value indicates whether the index was modified by the function. - bool AddOrUpdateManifest(const std::filesystem::path& manifestPath, const std::filesystem::path& relativePath); - - // Updates the manifest with matching { Id, Version, Channel } in the index. - // The return value indicates whether the index was modified by the function. - bool AddOrUpdateManifest(const Manifest::Manifest& manifest, const std::filesystem::path& relativePath); - - // Updates the manifest with matching { Id, Version, Channel } in the index. - // The return value indicates whether the index was modified by the function. - bool AddOrUpdateManifest(const Manifest::Manifest& manifest); - // Removes the manifest with matching { Id, Version, Channel } from the index. void RemoveManifest(const std::filesystem::path& manifestPath, const std::filesystem::path& relativePath); @@ -188,10 +176,7 @@ namespace AppInstaller::Repository::Microsoft // Internal functions to normalize on the relativePath being present. IdType AddManifestInternal(const Manifest::Manifest& manifest, const std::optional& relativePath); - IdType AddManifestInternalHoldingLock(const Manifest::Manifest& manifest, const std::optional& relativePath); bool UpdateManifestInternal(const Manifest::Manifest& manifest, const std::optional& relativePath); - bool UpdateManifestInternalHoldingLock(const Manifest::Manifest& manifest, const std::optional& relativePath); - bool AddOrUpdateManifestInternal(const Manifest::Manifest& manifest, const std::optional& relativePath); std::unique_ptr m_interface; Schema::SQLiteIndexContextData m_contextData; diff --git a/src/AppInstallerRepositoryCore/Microsoft/Schema/1_5/Interface.h b/src/AppInstallerRepositoryCore/Microsoft/Schema/1_5/Interface.h index 932a472b10..e102184bf5 100644 --- a/src/AppInstallerRepositoryCore/Microsoft/Schema/1_5/Interface.h +++ b/src/AppInstallerRepositoryCore/Microsoft/Schema/1_5/Interface.h @@ -26,11 +26,8 @@ namespace AppInstaller::Repository::Microsoft::Schema::V1_5 // Gets a property already knowing that the manifest id is valid. std::optional GetPropertyByManifestIdInternal(const SQLite::Connection& connection, SQLite::rowid_t manifestId, PackageVersionProperty property) const override; - private: - // Gets the ARP version ranges for the given package identifier. - std::vector GetArpVersionRanges(const SQLite::Connection& connection, SQLite::rowid_t packageIdentifier) const; - + private: // Semantic check to validate all arp version ranges within the index bool ValidateArpVersionConsistency(const SQLite::Connection& connection, bool log) const; }; -} +} \ No newline at end of file diff --git a/src/AppInstallerRepositoryCore/Microsoft/Schema/1_5/Interface_1_5.cpp b/src/AppInstallerRepositoryCore/Microsoft/Schema/1_5/Interface_1_5.cpp index db6a274026..105486ced8 100644 --- a/src/AppInstallerRepositoryCore/Microsoft/Schema/1_5/Interface_1_5.cpp +++ b/src/AppInstallerRepositoryCore/Microsoft/Schema/1_5/Interface_1_5.cpp @@ -4,7 +4,6 @@ #include "Microsoft/Schema/1_5/Interface.h" #include "Microsoft/Schema/1_5/ArpVersionVirtualTable.h" #include "Microsoft/Schema/1_0/ManifestTable.h" -#include "Microsoft/Schema/1_0/IdTable.h" #include "Microsoft/Schema/1_0/VersionTable.h" namespace AppInstaller::Repository::Microsoft::Schema::V1_5 @@ -37,32 +36,8 @@ namespace AppInstaller::Repository::Microsoft::Schema::V1_5 SQLite::rowid_t manifestId = V1_4::Interface::AddManifest(connection, manifest, relativePath); auto arpVersionRange = manifest.GetArpVersionRange(); - Manifest::string_t arpMinVersion, arpMaxVersion; - - if (!arpVersionRange.IsEmpty()) - { - // Check to see if adding this version range will create a conflict - SQLite::rowid_t packageIdentifier = V1_0::ManifestTable::GetIdById(connection, manifestId).value(); - std::vector ranges = GetArpVersionRanges(connection, packageIdentifier); - ranges.push_back(arpVersionRange); - - if (Utility::HasOverlapInVersionRanges(ranges)) - { - AICLI_LOG(Repo, Error, << "Overlapped Arp version ranges found for package. All ranges currently in index followed by new range:\n" << [&]() { - std::stringstream stream; - for (const auto& range : ranges) - { - stream << '[' << range.GetMinVersion().ToString() << "] - [" << range.GetMaxVersion().ToString() << "]\n"; - } - return std::move(stream).str(); - }()); - THROW_HR(APPINSTALLER_CLI_ERROR_ARP_VERSION_VALIDATION_FAILED); - } - - arpMinVersion = arpVersionRange.GetMinVersion().ToString(); - arpMaxVersion = arpVersionRange.GetMaxVersion().ToString(); - } - + Manifest::string_t arpMinVersion = arpVersionRange.IsEmpty() ? "" : arpVersionRange.GetMinVersion().ToString(); + Manifest::string_t arpMaxVersion = arpVersionRange.IsEmpty() ? "" : arpVersionRange.GetMaxVersion().ToString(); SQLite::rowid_t arpMinVersionId = V1_0::VersionTable::EnsureExists(connection, arpMinVersion); SQLite::rowid_t arpMaxVersionId = V1_0::VersionTable::EnsureExists(connection, arpMaxVersion); V1_0::ManifestTable::UpdateValueIdById(connection, manifestId, arpMinVersionId); @@ -107,27 +82,6 @@ namespace AppInstaller::Repository::Microsoft::Schema::V1_5 indexModified = true; } - if (!arpVersionRange.IsEmpty()) - { - // Check to see if the new set of version ranges created a conflict. - // We could have done this before attempting the update but it would be more complex and SQLite gives us easy rollback. - SQLite::rowid_t packageIdentifier = V1_0::ManifestTable::GetIdById(connection, manifestId).value(); - std::vector ranges = GetArpVersionRanges(connection, packageIdentifier); - - if (Utility::HasOverlapInVersionRanges(ranges)) - { - AICLI_LOG(Repo, Error, << "Overlapped Arp version ranges found for package. Ranges that would be present with attempted upgrade:\n" << [&]() { - std::stringstream stream; - for (const auto& range : ranges) - { - stream << '[' << range.GetMinVersion().ToString() << "] - [" << range.GetMaxVersion().ToString() << "]\n"; - } - return std::move(stream).str(); - }()); - THROW_HR(APPINSTALLER_CLI_ERROR_ARP_VERSION_VALIDATION_FAILED); - } - } - if (cleanOldMinVersionId && NotNeeded(connection, V1_0::VersionTable::TableName(), V1_0::VersionTable::ValueName(), oldMinVersionId)) { V1_0::VersionTable::DeleteById(connection, oldMinVersionId); @@ -227,26 +181,6 @@ namespace AppInstaller::Repository::Microsoft::Schema::V1_5 } } - std::vector Interface::GetArpVersionRanges(const SQLite::Connection& connection, SQLite::rowid_t packageIdentifier) const - { - std::vector ranges; - auto versionKeys = GetVersionKeysById(connection, packageIdentifier); - for (auto const& versionKey : versionKeys) - { - auto arpMinVersion = GetPropertyByPrimaryId(connection, versionKey.ManifestId, PackageVersionProperty::ArpMinVersion).value_or(""); - auto arpMaxVersion = GetPropertyByPrimaryId(connection, versionKey.ManifestId, PackageVersionProperty::ArpMaxVersion).value_or(""); - - // Either both empty or both not empty - THROW_HR_IF(E_UNEXPECTED, arpMinVersion.empty() != arpMaxVersion.empty()); - - if (!arpMinVersion.empty() && !arpMaxVersion.empty()) - { - ranges.emplace_back(Utility::VersionRange{ Utility::Version{ std::move(arpMinVersion) }, Utility::Version{ std::move(arpMaxVersion) } }); - } - } - return ranges; - } - bool Interface::ValidateArpVersionConsistency(const SQLite::Connection& connection, bool log) const { try @@ -259,7 +193,21 @@ namespace AppInstaller::Repository::Microsoft::Schema::V1_5 for (auto const& match : searchResult.Matches) { // Get arp version ranges for each package to check - std::vector ranges = GetArpVersionRanges(connection, match.first); + std::vector ranges; + auto versionKeys = GetVersionKeysById(connection, match.first); + for (auto const& versionKey : versionKeys) + { + auto arpMinVersion = GetPropertyByPrimaryId(connection, versionKey.ManifestId, PackageVersionProperty::ArpMinVersion).value_or(""); + auto arpMaxVersion = GetPropertyByPrimaryId(connection, versionKey.ManifestId, PackageVersionProperty::ArpMaxVersion).value_or(""); + + // Either both empty or both not empty + THROW_HR_IF(E_UNEXPECTED, arpMinVersion.empty() != arpMaxVersion.empty()); + + if (!arpMinVersion.empty() && !arpMaxVersion.empty()) + { + ranges.emplace_back(Utility::VersionRange{ Utility::Version{ std::move(arpMinVersion) }, Utility::Version{ std::move(arpMaxVersion) } }); + } + } // Check overlap if (Utility::HasOverlapInVersionRanges(ranges)) diff --git a/src/WinGetUtil/Exports.cpp b/src/WinGetUtil/Exports.cpp index 091f795d1e..bef1c56b59 100644 --- a/src/WinGetUtil/Exports.cpp +++ b/src/WinGetUtil/Exports.cpp @@ -192,26 +192,6 @@ extern "C" } CATCH_RETURN() - WINGET_UTIL_API WinGetSQLiteIndexAddOrUpdateManifest( - WINGET_SQLITE_INDEX_HANDLE index, - WINGET_STRING manifestPath, - WINGET_STRING relativePath, - BOOL* indexModified) try - { - THROW_HR_IF(E_INVALIDARG, !index); - THROW_HR_IF(E_INVALIDARG, !manifestPath); - THROW_HR_IF(E_INVALIDARG, !relativePath); - - bool result = reinterpret_cast(index)->AddOrUpdateManifest(manifestPath, relativePath); - if (indexModified) - { - *indexModified = (result ? TRUE : FALSE); - } - - return S_OK; - } - CATCH_RETURN() - WINGET_UTIL_API WinGetSQLiteIndexRemoveManifest( WINGET_SQLITE_INDEX_HANDLE index, WINGET_STRING manifestPath, diff --git a/src/WinGetUtil/Source.def b/src/WinGetUtil/Source.def index 2ec0f6637d..bc42f3dc6d 100644 --- a/src/WinGetUtil/Source.def +++ b/src/WinGetUtil/Source.def @@ -7,7 +7,6 @@ EXPORTS WinGetSQLiteIndexClose WinGetSQLiteIndexAddManifest WinGetSQLiteIndexUpdateManifest - WinGetSQLiteIndexAddOrUpdateManifest WinGetSQLiteIndexRemoveManifest WinGetSQLiteIndexPrepareForPackaging WinGetSQLiteIndexCheckConsistency diff --git a/src/WinGetUtil/WinGetUtil.h b/src/WinGetUtil/WinGetUtil.h index 86a69f1c04..13c548085d 100644 --- a/src/WinGetUtil/WinGetUtil.h +++ b/src/WinGetUtil/WinGetUtil.h @@ -158,14 +158,6 @@ extern "C" WINGET_STRING relativePath, BOOL* indexModified); - // Adds or Updates the manifest with matching { Id, Version, Channel } in the index. - // The return value indicates whether the index was modified by the function. - WINGET_UTIL_API WinGetSQLiteIndexAddOrUpdateManifest( - WINGET_SQLITE_INDEX_HANDLE index, - WINGET_STRING manifestPath, - WINGET_STRING relativePath, - BOOL* indexModified); - // Removes the manifest with matching { Id, Version, Channel } from the index. // Path is currently ignored. WINGET_UTIL_API WinGetSQLiteIndexRemoveManifest( diff --git a/src/WinGetUtilInterop.UnitTests/APIUnitTests/SQLiteIndexUnitTests.cs b/src/WinGetUtilInterop.UnitTests/APIUnitTests/SQLiteIndexUnitTests.cs index d2ae335ac4..ed8596e29d 100644 --- a/src/WinGetUtilInterop.UnitTests/APIUnitTests/SQLiteIndexUnitTests.cs +++ b/src/WinGetUtilInterop.UnitTests/APIUnitTests/SQLiteIndexUnitTests.cs @@ -1,4 +1,4 @@ -// ----------------------------------------------------------------------------- +// ----------------------------------------------------------------------------- // // Copyright (c) Microsoft Corporation. Licensed under the MIT License. // @@ -179,27 +179,6 @@ public void UpdateManifest() }); } - /// - /// Verify that add or update works both times. - /// - [Fact] - [DisplayTestMethodName] - public void AddOrUpdateManifest() - { - this.CreateIndexHelperForIndexTest((wrapper) => - { - // Add manifest. - string addManifest = Path.Combine(this.indexTestDataPath, PackageTest); - wrapper.AddOrUpdateManifest(addManifest, PackageTestRelativePath); - - // Update manifest. name is different, should return true. - string updateManifest = Path.Combine(this.indexTestDataPath, PackageTestNewName); - Assert.True(wrapper.AddOrUpdateManifest(updateManifest, PackageTestRelativePath)); - - return true; - }); - } - /// /// Verify that updating a manifest in the index with the exact same information succeeds. /// diff --git a/src/WinGetUtilInterop/Api/WinGetSQLiteIndex.cs b/src/WinGetUtilInterop/Api/WinGetSQLiteIndex.cs index 8a39390435..86c77f08a0 100644 --- a/src/WinGetUtilInterop/Api/WinGetSQLiteIndex.cs +++ b/src/WinGetUtilInterop/Api/WinGetSQLiteIndex.cs @@ -89,27 +89,6 @@ public bool UpdateManifest(string manifestPath, string relativePath) } } - /// - public bool AddOrUpdateManifest(string manifestPath, string relativePath) - { - try - { - // For now, modifying a manifest implies that the file didn't got moved in the repository. So only - // contents of the file are modified. However, in the future we might support moving which requires - // oldManifestPath, oldRelativePath, newManifestPath and oldManifestPath. - WinGetSQLiteIndexAddOrUpdateManifest( - this.indexHandle, - manifestPath, - relativePath, - out bool indexModified); - return indexModified; - } - catch (Exception e) - { - throw new WinGetSQLiteIndexException(e); - } - } - /// public void RemoveManifest(string manifestPath, string relativePath) { @@ -237,22 +216,6 @@ private static extern IntPtr WinGetSQLiteIndexUpdateManifest( string relativePath, [MarshalAs(UnmanagedType.U1)] out bool indexModified); - /// - /// Adds or Updates the manifest at the repository relative path in the index. - /// The out value indicates whether the index was modified by the function. - /// - /// Handle of the index. - /// Manifest path. - /// Relative path in the container. - /// Out bool if the index is modified. - /// HRESULT. - [DllImport(Constants.DllName, CallingConvention = CallingConvention.StdCall, CharSet = CharSet.Unicode, PreserveSig = false)] - private static extern IntPtr WinGetSQLiteIndexAddOrUpdateManifest( - IntPtr index, - string manifestPath, - string relativePath, - [MarshalAs(UnmanagedType.U1)] out bool indexModified); - /// /// Removes the manifest at the repository relative path from the index. /// diff --git a/src/WinGetUtilInterop/Interfaces/IWinGetSQLiteIndex.cs b/src/WinGetUtilInterop/Interfaces/IWinGetSQLiteIndex.cs index 96a5661765..68bc65d167 100644 --- a/src/WinGetUtilInterop/Interfaces/IWinGetSQLiteIndex.cs +++ b/src/WinGetUtilInterop/Interfaces/IWinGetSQLiteIndex.cs @@ -62,14 +62,6 @@ public interface IWinGetSQLiteIndex : IDisposable /// True if index was modified. bool UpdateManifest(string manifestPath, string relativePath); - /// - /// Adds or Updates manifest in the index. - /// - /// Path to manifest. - /// Path of the manifest in the repository. - /// True if index was modified. - bool AddOrUpdateManifest(string manifestPath, string relativePath); - /// /// Delete manifest from index. ///