[fidl][python] Initial creation and plumbing for fidlgen_python

This change implements a basic fidlgen_python and plumbs a new
fidl_python GN template through the fidl GN template so that FIDL
targets can enable_python to generate Python FIDL bindings for testing.

The initial implementation includes tests on a new conformance test
suite limited to the portions of the full conformance test suite
implemented by fidlgen_python. The limited conformance test suite
depends on the test.conformance.python FIDL library generated at build
time from a subset of the test.conformance FIDL library. I chose to
generate the test.conformance.python FIDL library at build time to
avoid duplicating test.conformance and being tempted to extend it
without also modifying test.conformance.

The overall goal of the initial fidlgen_python project is to have the
static bindings pass the same full conformance test suite that the
dynamic bindings pass without modifying the source code of the test
suite. So far, this appears achievable by mererly swapping the
fidl.test_conformance import at the top of the test suite with
fidl_test_conformance_python.

Test: Added fuchsia_controller_static_conformance_tests
Bug: 355717613, 356216300
Fixed: 356194806, 356207485, 356210680
Change-Id: I943f40e7f4bdff11a28900e50d48a8e549ef682a
Reviewed-on: https://fuchsia-review.googlesource.com/c/fuchsia/+/1188515
Reviewed-by: Ian McKellar <ianloic@google.com>
Reviewed-by: Christopher Johnson <crjohns@google.com>
Fuchsia-Auto-Submit: Charles Celerier <chcl@google.com>
Reviewed-by: Marc Khouri <mnck@google.com>
Commit-Queue: Auto-Submit <auto-submit@fuchsia-infra.iam.gserviceaccount.com>
23 files changed
tree: cf54ef643c1aba37efd732c0d6b33b3f04670e65
  1. .helix/
  2. boards/
  3. build/
  4. bundles/
  5. docs/
  6. examples/
  7. infra/
  8. products/
  9. scripts/
  10. sdk/
  11. src/
  12. third_party/
  13. tools/
  14. zircon/
  15. .clang-format
  16. .clang-tidy
  17. .editorconfig
  18. .git-blame-ignore-revs
  19. .gitattributes
  20. .gitignore
  21. .gitmodules
  22. .gn
  23. .ignore
  24. analysis_options.yaml
  25. AUTHORS
  26. BUILD.gn
  27. CODE_OF_CONDUCT.md
  28. CONTRIBUTING.md
  29. fuchsia.code-workspace
  30. LICENSE
  31. OWNERS
  32. PATENTS
  33. pyproject.toml
  34. pyrightconfig.json
  35. README.md
  36. rustfmt.toml
  37. shac.star
  38. shac.textproto
README.md

Fuchsia

What is Fuchsia?

Fuchsia is an open source, general purpose operating system supporting modern 64-bit Intel and ARM processors.

We expect everyone interacting with our project to respect our code of conduct.

Read more about Fuchsia's principles.

How can I build and run Fuchsia?

See Getting Started.

Where can I learn more about Fuchsia?

See fuchsia.dev.