tree: e2d2053f8b9c43b114b324d8003cb91b25357571 [path history] [tgz]
  1. foreign_type_in_response_used_through_compose/
  2. placement_of_attributes/
  3. struct_default_value_enum_library_reference/
  4. transitive_dependencies/
  5. transitive_dependencies_compose/
  6. type_aliases/
  7. anonymous.test.fidl
  8. arrays.test.fidl
  9. bindings_denylist.test.fidl
  10. bits.test.fidl
  11. bits_constants.test.fidl
  12. BUILD.gn
  13. byte_and_bytes.test.fidl
  14. constants.test.fidl
  15. consts.test.fidl
  16. doc_comments.test.fidl
  17. empty_struct.test.fidl
  18. encapsulated_structs.test.fidl
  19. enum.test.fidl
  20. error.test.fidl
  21. escaping.test.fidl
  22. experimental_maybe_from_type_alias.test.fidl
  23. handles.test.fidl
  24. handles_in_types.test.fidl
  25. info.gni
  26. inheritance.test.fidl
  27. inheritance_with_recursive_decl.test.fidl
  28. nullable.test.fidl
  29. padding.test.fidl
  30. protocol_request.test.fidl
  31. protocols.test.fidl
  32. README.md
  33. request_flexible_envelope.test.fidl
  34. service.test.fidl
  35. stamp.sh
  36. struct.test.fidl
  37. table.test.fidl
  38. union.test.fidl
  39. union_sandwich.test.fidl
  40. vectors.test.fidl
tools/fidl/fidlc/testdata/README.md

FIDL test libraries

This directory contains the FIDL test libraries used for golden files.

Add a new library

To add a new standalone library:

  1. Choose a name, e.g. foo_bar.
  2. Create a FIDL file with the .test.fidl extension, e.g. foo_bar.test.fidl.
  3. Declare the library as fidl.test. followed by name without underscores, e.g. library fidl.test.foobar;.
  4. Add the filename to the standalone_libraries list in BUILD.gn.
  5. Add an entry to fidl_testdata_info in info.gni, providing the name and the target that BUILD.gn generates, e.g.:
{
  name = "foo_bar"
  target = "//tools/fidl/fidlc/testdata:fidl.test.foobar"
}

Add a new library with dependencies

To add a new library with dependencies, you must create a subdirectory containing multiple FIDL files. This should only be done to accommodate dependencies, not to group together similar standalone libraries.

  1. Choose a name, e.g. foo_bar.
  2. Create a subdirectory named name containing two or more FIDL files ending in .test.fidl and a BUILD.gn to build them.
  3. Ensure one of the libraries is named appropriately, e.g. fidl.test.foobar, and that its build target name is the same.
  4. Add an entry to fidl_testdata_info in info.gni, providing the name and the target that BUILD.gn generates, e.g.:
{
  name = "foo_bar"
  target = "//tools/fidl/fidlc/testdata/foo_bar:fidl.test.foobar"
}

Golden tests

FIDL tools in //tools/fidl use the test libraries as input when defining golden tests with //build/testing/golden_test.gni.

To regenerate all goldens, run fx regen-goldens fidl.

To test goldens, run fx test ${TOOL}_golden_tests for the specific tool, e.g. fx test fidlc_golden_tests.