dart-sdk/pkg
Nate Biggs 924a33c0f5 [dart2js] Fix valid/invalid refinement logic.
The issue here was that isInMask does not hold inversely. The key is that we want to verify which refinements to skip, therefore we want to calculate *in*valid refinements. We want to skip refines where the new type is a Union AND the old tpye is a supertype of the new type. after.isInMask(before) gives us that but !before.isInMask(after) does not.

I've renamed isValidRefinement to isInvalidRefinement to more accurately capture this distinction.

Change-Id: I0d99479357a140095a5d0dfb7e2f987556097891
Reviewed-on: https://dart-review.googlesource.com/c/sdk/+/312160
Commit-Queue: Nate Biggs <natebiggs@google.com>
Reviewed-by: Mayank Patke <fishythefish@google.com>
2023-07-05 20:56:28 +00:00
..
_fe_analyzer_shared Add library macro definitions and support for executing them. 2023-07-05 18:56:53 +00:00
_js_interop_checks [dart:js_interop] Require top-level externals to have @JS 2023-06-22 18:45:21 +00:00
analysis_server Rework ElementImpl and AugmentationElementImpl hierarchies to use XyzOrAugmentationElementMixin(s). 2023-07-05 20:03:47 +00:00
analysis_server_client [analysis_server] Allow action in response to showMessageRequest to be null 2023-03-30 19:48:18 +00:00
analyzer Rework ElementImpl and AugmentationElementImpl hierarchies to use XyzOrAugmentationElementMixin(s). 2023-07-05 20:03:47 +00:00
analyzer_cli [analyzer_cli] [dartdev] Fix several tests on Windows 2023-06-04 19:26:11 +00:00
analyzer_plugin Deprecate ExecutableElement.returnType, use returnType2 instead. 2023-06-29 23:16:59 +00:00
analyzer_utilities [analysis_server] Fix generation tests on Windows 2023-06-04 19:18:51 +00:00
async_helper
build_integration
compiler [dart2js] Fix valid/invalid refinement logic. 2023-07-05 20:56:28 +00:00
dap [dap] Regenerate DAP classes based on latest published version of spec 2023-06-20 17:29:24 +00:00
dart2js_info
dart2js_runtime_metrics
dart2js_tools
dart2native [vm/ffi] dartdev CLI native-assets 2023-05-30 09:10:28 +00:00
dart2wasm [vm] Async FFI callbacks 2023-06-28 01:00:18 +00:00
dart_internal Update package:dart_internal to work with SDK 3.2.0. 2023-06-21 01:14:38 +00:00
dartdev [deps/ffi] Unbundle package:native_assets_builder 2023-06-28 09:09:09 +00:00
dds [dds/dap] Fix breakpoint resolution races when there are multiple isolates 2023-06-27 14:54:10 +00:00
dds_service_extensions Revert "Revert "Send DAP events through DDS"" - only check for event handler when DDS URI is also set. 2023-06-22 21:43:22 +00:00
dev_compiler [ddc] Add --canary flag to expression compiler worker 2023-06-26 22:55:07 +00:00
expect [vm] Add @pragma('vm:keep-name') annotation 2023-06-16 10:22:23 +00:00
front_end Add library macro definitions and support for executing them. 2023-07-05 18:56:53 +00:00
frontend_server [frontend_server] Add --canary flag 2023-06-27 22:21:04 +00:00
js [pkg:js] Update min sdk version to 3.1.0-66.0.dev 2023-05-04 15:56:41 +00:00
js_ast [dart2js] Better const Maps and Sets 2023-06-20 23:44:08 +00:00
js_runtime [dart2js] Improve deferred part file logging. 2023-06-09 17:05:11 +00:00
js_shared
kernel [cfe] Add FileUriConstantExpression 2023-06-28 07:52:09 +00:00
language_versioning_2_7_test
meta
mmap [pkg] Support mmap with all the Linux architectures. 2023-05-11 17:15:26 +00:00
modular_test
native_stack_traces [vm] Rework awaiter stack unwinding. 2023-06-30 14:03:03 +00:00
nnbd_migration Add InterfaceElementImpl, move many methods into it. 2023-07-04 01:41:38 +00:00
scrape Deprecate IfElement/IfStatement.condition, use 'expression'. 2023-04-19 17:17:28 +00:00
smith [infra] Change default NNBD to strong. 2023-05-24 20:48:36 +00:00
sourcemap_testing
status_file Remove the old now-unused PubGetError test expectation. 2023-04-28 13:15:26 +00:00
telemetry Implement broad-spectrum filtering for possible path and filenames in exception strings. 2023-05-16 15:25:37 +00:00
test_runner [deps/ffi] Unbundle package:native_assets_builder 2023-06-28 09:09:09 +00:00
testing [cfe] Remove unnecessary_null_comparison code 2023-06-08 08:46:47 +00:00
vm [pkg/vm] Instantiate the ffi Pointer class to bounds when needed. 2023-07-05 14:24:56 +00:00
vm_service [vm] Rework awaiter stack unwinding. 2023-06-30 14:03:03 +00:00
vm_service_protos [VM/Service] Create package:vm_service_protos for distributing code for working with Perfetto protos 2023-06-15 19:01:00 +00:00
vm_snapshot_analysis [gardening] Update PatchClass::patched_class_ to wrapped_class_ in pkg/vm_snapshot_analsysis. 2023-06-29 18:34:37 +00:00
wasm_builder [dart2wasm] Close parens in compile-time error messages 2023-04-05 16:36:27 +00:00
.gitignore
analysis_options.yaml
BUILD.gn
OWNERS
pkg.dart
pkg.status [deps/ffi] Unbundle package:native_assets_builder 2023-06-28 09:09:09 +00:00
README.md

Package validation

The packages in pkg/ are automatically validated on the LUCI CI bots. The validation is largely done by the tools/package_deps package; it can be tested locally via:

dart tools/package_deps/bin/package_deps.dart

Packages which are published

There are several packages developed in pkg/ which are published to pub. Validation of these packages is particularly important because the pub tools are not used for these packages during development; we get our dependency versions from the DEPS file. Its very easy for the dependencies specified in a package's pubspec file to get out of date wrt the packages and versions actually used.

In order to better ensure we're publishing correct packages, we validate some properties of the pubspec files on our CI system. These validations include:

  • that the dependencies listed in the pubspec are used in the package
  • that all the packages used by the source are listed in the pubspec
  • that we don't use relative path deps to pkg/ or third_party/ packages

Packages which are not published

For packages in pkg/ which we do not intend to be published, we put the following comment in the pubspec.yaml file:

# This package is not intended for consumption on pub.dev. DO NOT publish.
publish_to: none

These pubspecs are still validated by the package validation tool. The contents are more informational as the pubspecs for these packages are not consumed by the pub tool or ecosystem.

We validate:

  • that the dependencies listed in the pubspec are used in the package
  • that all the packages used by the source are listed in the pubspec
  • that a reference to a pkg/ package is done via a relative path dependency