dart-sdk/pkg
Ryan Macnak 139ff289db [vm, compiler] Allocation canaries.
Before each allocation, check the memory hasn't been touched since page initialization. This more reliably detects the issue fixed in a4381f127c.

TEST=ci
Change-Id: I5c0ed0a18a32515eab2ae90110b5a7e7f48779dc
Reviewed-on: https://dart-review.googlesource.com/c/sdk/+/325366
Commit-Queue: Ryan Macnak <rmacnak@google.com>
Reviewed-by: Siva Annamalai <asiva@google.com>
2023-09-15 17:04:55 +00:00
..
_fe_analyzer_shared [_fe_analyzer_shared] Ensure beginToken on class, enum, mixin, extension and extension type 2023-09-15 13:01:10 +00:00
_js_interop_checks [dart:js_interop_unsafe] Rename extensions and make []/[]= take String properties 2023-09-12 23:11:55 +00:00
analysis_server analyzer: add doc directive support for example and macro 2023-09-13 18:03:42 +00:00
analysis_server_client Extension type. Tests for type hierarchy. 2023-08-30 21:18:25 +00:00
analyzer [_fe_analyzer_shared] Ensure beginToken on class, enum, mixin, extension and extension type 2023-09-15 13:01:10 +00:00
analyzer_cli Refactor PubspecValidator 2023-08-16 12:31:30 +00:00
analyzer_plugin Extension type. Create navigation regions for primary constructor and representation field. 2023-09-07 18:20:50 +00:00
analyzer_utilities Update analyzer_utilties to Dart 3 and enable more lints 2023-09-14 20:27:26 +00:00
async_helper Fix behavior of Stream.empty. 2023-08-17 15:26:59 +00:00
bisect_dart [tool] bisect.dart fix prints 2023-08-25 09:14:40 +00:00
build_integration
compiler [dart2js] Remove uses of OnceConstantVisitorDefaultMixin 2023-09-14 22:26:39 +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] cleanup backend usage (I) 2023-08-10 22:45:54 +00:00
dart2js_runtime_metrics
dart2js_tools
dart2native [ CLI ] Remove --enable-asserts option for dart compile aot-snapshot 2023-08-24 19:27:29 +00:00
dart2wasm [vm, dart2wasm] Early lowering of FunctionTearOff nodes 2023-09-15 16:54:08 +00:00
dart_internal Increase maximum sdk version constraint on dart_internal to 3.3.0 2023-07-27 00:29:42 +00:00
dartdev [dartdev/test] Added missing test case for https://github.com/dart-lang/sdk/issues/52892 2023-09-01 21:05:04 +00:00
dds Add a retry to the DevTools handler for static files 2023-09-12 18:52:01 +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 [cfe] Make (Tree)Visitor(1) pure interfaces 2023-09-14 10:59:26 +00:00
expect [dart2js] Add Dart web speciailized expectation helpers. 2023-08-11 20:59:30 +00:00
front_end [vm, dart2wasm] Early lowering of FunctionTearOff nodes 2023-09-15 16:54:08 +00:00
frontend_server [dart2wasm] Support for kernel_worker and unevaluated constants. 2023-09-06 18:02:58 +00:00
js
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] Make (Tree)Visitor(1) pure interfaces 2023-09-14 10:59:26 +00:00
language_versioning_2_7_test
linter fix unsafe cast 2023-09-14 19:27:58 +00:00
meta + extension type target kind (and @optionalTypeArgs support) 2023-09-08 18:09:01 +00:00
mmap
modular_test [modular_test] second attempt to fix shards. 2023-07-27 22:29:07 +00:00
native_stack_traces [vm] Rework awaiter stack unwinding. 2023-06-30 14:03:03 +00:00
nnbd_migration [analyzer] Remove all support for strong-mode 2023-08-17 17:07:37 +00:00
scrape [analyzer] Remove unused, old feature methods from old parser 2023-08-15 19:14:17 +00:00
service_extension_router Initial commit for pkg/service_extension_router 2023-08-30 20:18:12 +00:00
smith [dart2wasm,smith] Add options support in test_matrix.json, jscm builder 2023-09-11 10:50:22 +00:00
sourcemap_testing
status_file [infra] Make the sanitizer a first-class status variable. 2023-07-10 17:46:31 +00:00
telemetry
test_runner [vm, compiler] Allocation canaries. 2023-09-15 17:04:55 +00:00
testing [cfe] Remove unnecessary_null_comparison code 2023-06-08 08:46:47 +00:00
vm [vm, dart2wasm] Early lowering of FunctionTearOff nodes 2023-09-15 16:54:08 +00:00
vm_service Avoid passing a nullable value to Completer<nn-type>.completer. 2023-09-06 19:54:00 +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 [pkg/vm_snapshot_analysis] Allow old 'patched_class_' field. 2023-07-07 11:36:59 +00:00
wasm_builder [wasm_builder] Fix --watch option to work with instructions 2023-09-07 10:43:49 +00:00
.gitignore
analysis_options.yaml
BUILD.gn
OWNERS
pkg.dart
pkg.status [linter] Only run linter unit tests on the vm runtime 2023-08-23 13:13:47 +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