-
Notifications
You must be signed in to change notification settings - Fork 1.5k
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
Convert from optional package to app extension for source data #92
Conversation
…pipeline even if other passes fail
Where is the source for these checked in test packages? #ByDesign Refers to: src/AppInstallerCLITests/TestData/index.1.0.0.0.msix:1 in de0718e. [](commit_id = de0718e, deletion_comment = False) |
@@ -49,44 +49,6 @@ namespace AppInstaller::Deployment | |||
AICLI_LOG(Core, Info, << "Successfully deployed #" << id); | |||
} | |||
} | |||
|
|||
// Type that exists simply to enabled a fire and forget register call as we exit. | |||
struct DelayRegisterStorage |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
elayRegisterStorage [](start = 16, length = 19)
👍 #Closed
static constexpr std::string_view s_PreIndexedPackageSourceFactory_AppxManifestFileName = "AppxManifest.xml"sv; | ||
static constexpr std::string_view s_PreIndexedPackageSourceFactory_IndexFileName = "index.db"sv; | ||
// TODO: This being hard coded to force using the Public directory name is not ideal. | ||
static constexpr std::string_view s_PreIndexedPackageSourceFactory_IndexFilePath = "Public\\index.db"sv; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
when we add the new source, we cant discover the export/cache it? #WontFix
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We do discover it from the APIs for a deployed package. This is for extracting the file directly. I could see if we can get the extension info from the manifest.
In reply to: 416820905 [](ancestors = 416820905)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
In what flow do we extract the file directly? the unpackaged case/
In reply to: 416845621 [](ancestors = 416845621,416820905)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, the case where we are running outside of a package.
In reply to: 416870267 [](ancestors = 416870267,416845621,416820905)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It doesn't look like there is easy access to the data from the manifest reader. We would have to open it with MSXML and select the appropriate element. I don't think it worth that for this case.
In reply to: 416951996 [](ancestors = 416951996,416870267,416845621,416820905)
std::vector<std::string> m_familyNames; | ||
}; | ||
|
||
DelayRegisterStorage s_delayRegisterStorage; | ||
} | ||
|
||
void RequestAddPackageAsync( |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
geAsync( [](start = 24, length = 8)
this function waits for the request to finish, so why would it be called async? #Resolved
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Just copying the name of the underlying function. Can change it if you prefer.
In reply to: 416822681 [](ancestors = 416822681)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
since we wait, i would think this is misleading. #UpToCodeOwner
In reply to: 416844618 [](ancestors = 416844618,416822681)
@@ -258,7 +258,7 @@ namespace AppInstaller::Repository::Microsoft | |||
return; | |||
} | |||
|
|||
packageInfo.WriteToFile(s_PreIndexedPackageSourceFactory_IndexFileName, indexPath, progress); | |||
packageInfo.WriteToFile(s_PreIndexedPackageSourceFactory_IndexFilePath, indexPath, progress); | |||
packageInfo.WriteManifestToFile(manifestPath, progress); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
why do we write these files out"? #Closed
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@@ -160,7 +163,7 @@ namespace AppInstaller::Repository::Microsoft | |||
return; | |||
} | |||
|
|||
std::filesystem::path packagePath = optionalPackage.value(); | |||
std::filesystem::path packagePath = extension->GetPackagePath(); | |||
std::filesystem::path manifestPath = packagePath / s_PreIndexedPackageSourceFactory_AppxManifestFileName; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
anifestPath = packagePath / s_PreIndexedPac [](start = 43, length = 43)
this is refering to the installed extension, right? SHouldn't we query the system for version rather than manually extract it? #Resolved
Can't these packages be updated externally to winget? Wouldn't it be more correct to always lookup what package is installed associated with the known family? If i updated a source, then via settings or appinstaller or manual, or whatever trigger an update of the source package, this details cached state gets torn? #ByDesign Refers to: src/AppInstallerRepositoryCore/Microsoft/PreIndexedPackageSourceFactory.cpp:175 in de0718e. [](commit_id = de0718e, deletion_comment = False) |
IIRC. the details feeds into the settings which get written out by winget? In reply to: 620778316 [](ancestors = 620778316) Refers to: src/AppInstallerRepositoryCore/Microsoft/PreIndexedPackageSourceFactory.cpp:175 in de0718e. [](commit_id = de0718e, deletion_comment = False) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
🕐
The full name is not how the extension is filtered for, the family name is. So while this records the full name of the package that we saw, we will always just open the extension with this family name. The only reason to leave it the full name that we stores is diagnostic. In reply to: 620780114 [](ancestors = 620780114,620778316) Refers to: src/AppInstallerRepositoryCore/Microsoft/PreIndexedPackageSourceFactory.cpp:175 in de0718e. [](commit_id = de0718e, deletion_comment = False) |
They are the source. Unpack / modify / repack. In reply to: 620763710 [](ancestors = 620763710) Refers to: src/AppInstallerCLITests/TestData/index.1.0.0.0.msix:1 in de0718e. [](commit_id = de0718e, deletion_comment = False) |
azure-pipelines.yml
Outdated
@@ -193,6 +196,7 @@ jobs: | |||
displayName: Prepare VSTest for E2E Tests | |||
inputs: | |||
packageFeedSelector: 'nugetOrg' | |||
condition: succeededOrFailed() |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
condition: succeededOrFailed() [](start = 4, length = 30)
If this failed, tests can't be run. #ByDesign
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm not sure that there is a good alternative to this to ensure that every test runs. If this fails and the tests also fail, thats probably fine.
In reply to: 417623514 [](ancestors = 417623514)
azure-pipelines.yml
Outdated
@@ -157,13 +158,15 @@ jobs: | |||
script: | | |||
Add-AppxPackage AppInstallerCLIPackage_0.0.0.2_Test\Dependencies\x86\Microsoft.VCLibs.x86.14.00.Desktop.appx | |||
workingDirectory: $(appxPackageDir) | |||
condition: succeededOrFailed() |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
condition: succeededOrFailed() [](start = 4, length = 30)
If you are adding this for dependency package, then we should update the x64 one above to be consistent
#Resolved
<Resources> | ||
<Resource Language="en-US" /> | ||
<Resource Language="und" /> |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
und [](start = 24, length = 3)
Is this intended? #ByDesign
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, it is language independent, which is what und is for.
In reply to: 417656686 [](ancestors = 417656686)
@@ -16,7 +16,7 @@ public void HashCommands() | |||
Assert.True(result.StdOut.Contains("9b4c49ad7e47afd97d2e666e93347745e1647c55f1a7ebba6d31b7dd5f69ee68")); | |||
|
|||
// Hash msix | |||
result = TestCommon.RunAICLICommand("hash", TestCommon.GetTestDataFile(Constants.PlaceholderPackageFile) + " -m"); | |||
result = TestCommon.RunAICLICommand("hash", TestCommon.GetTestDataFile(Constants.TestPackage) + " -m"); | |||
Assert.AreEqual(Constants.ErrorCode.S_OK, result.ExitCode); | |||
Assert.True(result.StdOut.Contains("08917b781939a7796746b5e2349e1f1d83b6c15599b60cd3f62816f15e565fc4")); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
08917b781939a7796746b5e2349e1f1d83b6c15599b60cd3f62816f15e565fc4 [](start = 48, length = 64)
I think this is going to change. By the way, how did you sign the package? #ByDesign
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why would it change? This is the same package (I just renamed it).
In reply to: 417662780 [](ancestors = 417662780)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
does this work...
Nope. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
2dfc7499 Update Authors file 6dab4978 Update README and tweak syntax in Boost.JSON adapter 2ecd2119 Merge pull request microsoft#136 from matty0ung/boostjson b1119ccc Merge pull request microsoft#135 from matty0ung/uris f5cf601e Add Boost.JSON support 14325788 Add Boost.JSON support d3104ea8 Support fetching sub-schemas from other files ad7dac75 Merge pull request microsoft#133 from rayvincent2/feature/add-urn-reference-support 3442709a Update urn regex expression to be std::regex safe f787a8a7 Update urn regex to match widely accepted expression 653d515d Ensure that urn regex checks to end of string eac0859c Ensure that urn NID cannot include '.' ef42dae2 Add support for urn document references a4684c28 Fix path to rapidjson in fuzzing test code 11af6522 Merge remote-tracking branch 'clainio/build-fix' c5487c39 Update rapidjson to latest code from github 6a04040d Update adapters to avoid inheriting from std::iterator 385d2d83 Improve handling of compiler flags when exceptions are disabled 82e093fe Upgrade gtest to v1.11.0 c63ac26f Disable C4702: unreachable code warnings for json_pointer.hpp 855365bc Disable C4702: unreachable code warnings within relevant headers 5c97e3cc Fix gcc build error 4897d102 Fix exclusiveMaximum and exclusiveMinimum error messages 6cc4cddc Suppress boost warnings that aren't relevant to the test suite 2cf8d3dd Add default tests for draft 7 e94179e1 Add definitions tests for draft 7 bb2c4251 Improve array_iteration_basics example e6909b15 Add required test for draft 4 df89869e Add maxLength and minLength tests for draft 7 91834621 Fix return type on getMinLength 3740dc51 Explicitly initialise optionals in Subschema class cb778b6b Minor changes to address msvc warnings and make cmake work on Windows 70f12ed1 Merge pull request microsoft#123 from anishmonachan7/fix_unused_variable 03b8cccb Update include/valijson/constraints/concrete_constraints.hpp dc6d2fe0 fix unused variable error with gcc 8.3 77bae9fb Fix xcode stuff 66262baf Include nlohmann/json.hpp instead of json.hpp b3b958c8 Merge pull request microsoft#121 from anishmonachan7/virtual_destructor 84c9fbf5 destructor to virtual destructor 8a784f23 Minor fix for example code in README a19e1c00 Remove warning suppressions for clang af2358b6 Use custom RAPIDJSON_ASSERT macro to catch parser errors 7ab96207 Ensure ref values are strings 635f36f0 Merge pull request microsoft#119 from BSipos-RKF/issue-118 fba5a9e8 Reject JSON references that index into empty arrays cbcde15c Possible fix for microsoft#118 3621f98d Update rapidjson_utils.hpp to use iterative parsing f544cd02 Merge pull request microsoft#116 from AdamKorcz/fuzz1 c13eed99 Minor refactoring 3a47f0cd Added fuzzer with oss-fuzz build file cf648930 Merge pull request microsoft#114 from baylesj/fix-memory-leak 1f964c12 Fix memory leak in concrete constraints 7cb31947 Merge pull request microsoft#113 from hei-pa/master 8cc83c8b move curlpp findPackage in EXAMPLES block c1e75c70 Merge pull request microsoft#110 from baylesj/remote_throws bc81adbd add version checks around BOOST_NORETURN 7a560db2 Fixup headers b8e95810 Apply feedback, add boost version check 8f6f9b6a Use deprecated declarations f1006142 Cleanup unnecessary returns a30ef974 Add VALIJSON_USE_EXCEPTIONS mode 8a700811 Add JSON Inspector example app bbfc3f5c Fixed build on certain GCC toolchains 84b67fa6 Merge pull request microsoft#107 from baylesj/readme 90783ca4 Minor code style changes 3dd4482a Merge pull request microsoft#103 from wwriter/cond_schema_errormessage ee4f85bf Minor tweaks to README.md file a7038862 Update jsoncpp link in readme abedaf0e Merge pull request microsoft#105 from baylesj/update-jsoncpp 825ee110 Fix readme b6b6f167 Delete jsoncpp fuzzing stuff 2ee7474f Delete more unnecessary scripts 1ff5308f fix submodule dbc4fcc8 Remove modules 88d9d890 Update JsonCpp to 1.9.4 d5091b2d added feature : now users can get a detailed error message when if-then-else conditional constraints are not met 931f64d4 Merge pull request microsoft#102 from mathbunnyru/patch-2 c5e61543 Add conan package manager info 6cda9227 Merge pull request microsoft#99 from mathbunnyru/patch-1 45b0f83b Fix README so the code actually throws, when json is invalid 89e37cbf Fix typo 7f01c391 Minor suggestions from clangtidy a527564b Merge pull request microsoft#96 from joshuaeckroth/master ccad6b14 Switched from jsoncpp deprecated Reader to CharReader 45a333e6 Try to make builds faster 0ee3bada Fix broken build bbe62ecd Merge pull request microsoft#95 from wirenboard/feature/cache-regex f7f3acf2 Merge pull request microsoft#94 from wirenboard/fix/pass-by-ref 39f35069 Regex objects cache for pattern constraints 2216c2b8 Pass visitor to validationCallback by ref 0db0d139 Merge pull request microsoft#93 from Delgan/fix-unused-args 1c825cc6 Remove unused parameters instead of commenting them out ca031221 Fix compilation errors due to unused parameters 105e345a Merge pull request microsoft#92 from arthurafarias/add-cmake-interface-library f60a3089 Added interface target to CMakeLists.txt d453ee2e Revert breaking changes to jsoncpp_adapter.hpp f3a0390e Revert changes to json11_adapter.hpp 49c20301 Disable -Wshadow for included header in property_tree_utils.hpp 8875d802 Add CLion paths to .gitignore 73a8e440 More aggressive compiler warnings 77d2ef82 Cosmetic improvements for poco_json_adapter.hpp and property_tree_adapter.hpp e5c1cbfe Ensure tests are run for Poco, Qt and property_tree adapters 8c0d16a0 Cosmetic improvements for std_string_adapter.hpp, test_json_pointer.cpp and test_poly_constraint.cpp 217b990b Cosmetic improvements for schema_parser.hpp and validation_results.hpp 71f4cdaa Cosmetic improvements for custom_allocator.hpp e46af245 Cosmetic improvements for concrete_constraints.hpp and basic_constraint.hpp 7917b2f7 Cosmetic improvements for schema.hpp, schema_parser.hpp and subschema.hpp 8150a520 Cosmetic improvements for test_adapter_comparison.cpp 28cc9e8e Cosmetic improvements for qtjson_adapter.hpp 508bc019 Cosmetic improvements for rapidjson_adapter.hpp d7901d48 Cosmetics improvements for picojson_adapter.hpp 3211a04d Cosmetic improvements for nlohmann_json_adapter.hpp 0f57cb31 Cosmetic improvements for jsoncpp_adapter.hpp e11c17c3 Cosmetic improvements for json11_adapter.hpp 6f1f4acb Cosmetic improvements for basic_adapter.hpp 3ddbe585 Cosmetic improvements for validation_visitor.hpp 09d21423 Update xcode project files 0481a0bb Minor tidy up of const auto usage 94cef2fa Add example showing local file resolution git-subtree-dir: src/Valijson/valijson git-subtree-split: 2dfc7499a31b84edef71189f4247919268ebc74e
2dfc7499 Update Authors file 6dab4978 Update README and tweak syntax in Boost.JSON adapter 2ecd2119 Merge pull request microsoft#136 from matty0ung/boostjson b1119ccc Merge pull request microsoft#135 from matty0ung/uris f5cf601e Add Boost.JSON support 14325788 Add Boost.JSON support d3104ea8 Support fetching sub-schemas from other files ad7dac75 Merge pull request microsoft#133 from rayvincent2/feature/add-urn-reference-support 3442709a Update urn regex expression to be std::regex safe f787a8a7 Update urn regex to match widely accepted expression 653d515d Ensure that urn regex checks to end of string eac0859c Ensure that urn NID cannot include '.' ef42dae2 Add support for urn document references a4684c28 Fix path to rapidjson in fuzzing test code 11af6522 Merge remote-tracking branch 'clainio/build-fix' c5487c39 Update rapidjson to latest code from github 6a04040d Update adapters to avoid inheriting from std::iterator 385d2d83 Improve handling of compiler flags when exceptions are disabled 82e093fe Upgrade gtest to v1.11.0 c63ac26f Disable C4702: unreachable code warnings for json_pointer.hpp 855365bc Disable C4702: unreachable code warnings within relevant headers 5c97e3cc Fix gcc build error 4897d102 Fix exclusiveMaximum and exclusiveMinimum error messages 6cc4cddc Suppress boost warnings that aren't relevant to the test suite 2cf8d3dd Add default tests for draft 7 e94179e1 Add definitions tests for draft 7 bb2c4251 Improve array_iteration_basics example e6909b15 Add required test for draft 4 df89869e Add maxLength and minLength tests for draft 7 91834621 Fix return type on getMinLength 3740dc51 Explicitly initialise optionals in Subschema class cb778b6b Minor changes to address msvc warnings and make cmake work on Windows 70f12ed1 Merge pull request microsoft#123 from anishmonachan7/fix_unused_variable 03b8cccb Update include/valijson/constraints/concrete_constraints.hpp dc6d2fe0 fix unused variable error with gcc 8.3 77bae9fb Fix xcode stuff 66262baf Include nlohmann/json.hpp instead of json.hpp b3b958c8 Merge pull request microsoft#121 from anishmonachan7/virtual_destructor 84c9fbf5 destructor to virtual destructor 8a784f23 Minor fix for example code in README a19e1c00 Remove warning suppressions for clang af2358b6 Use custom RAPIDJSON_ASSERT macro to catch parser errors 7ab96207 Ensure ref values are strings 635f36f0 Merge pull request microsoft#119 from BSipos-RKF/issue-118 fba5a9e8 Reject JSON references that index into empty arrays cbcde15c Possible fix for microsoft#118 3621f98d Update rapidjson_utils.hpp to use iterative parsing f544cd02 Merge pull request microsoft#116 from AdamKorcz/fuzz1 c13eed99 Minor refactoring 3a47f0cd Added fuzzer with oss-fuzz build file cf648930 Merge pull request microsoft#114 from baylesj/fix-memory-leak 1f964c12 Fix memory leak in concrete constraints 7cb31947 Merge pull request microsoft#113 from hei-pa/master 8cc83c8b move curlpp findPackage in EXAMPLES block c1e75c70 Merge pull request microsoft#110 from baylesj/remote_throws bc81adbd add version checks around BOOST_NORETURN 7a560db2 Fixup headers b8e95810 Apply feedback, add boost version check 8f6f9b6a Use deprecated declarations f1006142 Cleanup unnecessary returns a30ef974 Add VALIJSON_USE_EXCEPTIONS mode 8a700811 Add JSON Inspector example app bbfc3f5c Fixed build on certain GCC toolchains 84b67fa6 Merge pull request microsoft#107 from baylesj/readme 90783ca4 Minor code style changes 3dd4482a Merge pull request microsoft#103 from wwriter/cond_schema_errormessage ee4f85bf Minor tweaks to README.md file a7038862 Update jsoncpp link in readme abedaf0e Merge pull request microsoft#105 from baylesj/update-jsoncpp 825ee110 Fix readme b6b6f167 Delete jsoncpp fuzzing stuff 2ee7474f Delete more unnecessary scripts 1ff5308f fix submodule dbc4fcc8 Remove modules 88d9d890 Update JsonCpp to 1.9.4 d5091b2d added feature : now users can get a detailed error message when if-then-else conditional constraints are not met 931f64d4 Merge pull request microsoft#102 from mathbunnyru/patch-2 c5e61543 Add conan package manager info 6cda9227 Merge pull request microsoft#99 from mathbunnyru/patch-1 45b0f83b Fix README so the code actually throws, when json is invalid 89e37cbf Fix typo 7f01c391 Minor suggestions from clangtidy a527564b Merge pull request microsoft#96 from joshuaeckroth/master ccad6b14 Switched from jsoncpp deprecated Reader to CharReader 45a333e6 Try to make builds faster 0ee3bada Fix broken build bbe62ecd Merge pull request microsoft#95 from wirenboard/feature/cache-regex f7f3acf2 Merge pull request microsoft#94 from wirenboard/fix/pass-by-ref 39f35069 Regex objects cache for pattern constraints 2216c2b8 Pass visitor to validationCallback by ref 0db0d139 Merge pull request microsoft#93 from Delgan/fix-unused-args 1c825cc6 Remove unused parameters instead of commenting them out ca031221 Fix compilation errors due to unused parameters 105e345a Merge pull request microsoft#92 from arthurafarias/add-cmake-interface-library f60a3089 Added interface target to CMakeLists.txt d453ee2e Revert breaking changes to jsoncpp_adapter.hpp f3a0390e Revert changes to json11_adapter.hpp 49c20301 Disable -Wshadow for included header in property_tree_utils.hpp 8875d802 Add CLion paths to .gitignore 73a8e440 More aggressive compiler warnings 77d2ef82 Cosmetic improvements for poco_json_adapter.hpp and property_tree_adapter.hpp e5c1cbfe Ensure tests are run for Poco, Qt and property_tree adapters 8c0d16a0 Cosmetic improvements for std_string_adapter.hpp, test_json_pointer.cpp and test_poly_constraint.cpp 217b990b Cosmetic improvements for schema_parser.hpp and validation_results.hpp 71f4cdaa Cosmetic improvements for custom_allocator.hpp e46af245 Cosmetic improvements for concrete_constraints.hpp and basic_constraint.hpp 7917b2f7 Cosmetic improvements for schema.hpp, schema_parser.hpp and subschema.hpp 8150a520 Cosmetic improvements for test_adapter_comparison.cpp 28cc9e8e Cosmetic improvements for qtjson_adapter.hpp 508bc019 Cosmetic improvements for rapidjson_adapter.hpp d7901d48 Cosmetics improvements for picojson_adapter.hpp 3211a04d Cosmetic improvements for nlohmann_json_adapter.hpp 0f57cb31 Cosmetic improvements for jsoncpp_adapter.hpp e11c17c3 Cosmetic improvements for json11_adapter.hpp 6f1f4acb Cosmetic improvements for basic_adapter.hpp 3ddbe585 Cosmetic improvements for validation_visitor.hpp 09d21423 Update xcode project files 0481a0bb Minor tidy up of const auto usage 94cef2fa Add example showing local file resolution git-subtree-dir: src/Valijson/valijson git-subtree-split: 2dfc7499a31b84edef71189f4247919268ebc74e
Change
Using an optional package presented too many hurdles, and didn't allow (as easily) to enable source packages containing custom functionality in the future. This change moves to using app extension packages, which allows us to bypass the problems that we were facing before. Other than a few manifest changes and the location of the index within the package, very little has changed for the package. But the code is much simpler, and can now update and remove the source while running.
Also:
Testing
Tests were updated for this change, but otherwise this should be covered through their regression coverage.