Add fuzzer for Inspector

BUG=tint:445

Change-Id: Ic342c7e83827bcc57bfd134dec92b03cb9708a70
Reviewed-on: https://dawn-review.googlesource.com/c/tint/+/37540
Auto-Submit: Ryan Harrison <rharrison@chromium.org>
Reviewed-by: dan sinclair <dsinclair@chromium.org>
Commit-Queue: Ryan Harrison <rharrison@chromium.org>
diff --git a/BUILD.gn b/BUILD.gn
index 6c0c5f5..d51ecb4 100644
--- a/BUILD.gn
+++ b/BUILD.gn
@@ -1366,6 +1366,11 @@
       sources = [ "fuzzers/tint_first_index_offset_fuzzer.cc" ]
       deps = [ ":tint_fuzzer_common" ]
     }
+
+    fuzzer_test("tint_inspector_fuzzer") {
+      sources = [ "fuzzers/tint_inspector_fuzzer.cc" ]
+      deps = [ ":tint_fuzzer_common" ]
+    }
   }
 
   if (tint_build_wgsl_reader && tint_build_hlsl_writer) {
diff --git a/fuzzers/CMakeLists.txt b/fuzzers/CMakeLists.txt
index 50b43a1..e462db2 100644
--- a/fuzzers/CMakeLists.txt
+++ b/fuzzers/CMakeLists.txt
@@ -34,6 +34,7 @@
   add_tint_fuzzer(tint_bound_array_accessors_fuzzer)
   add_tint_fuzzer(tint_emit_vertex_point_size_fuzzer)
   add_tint_fuzzer(tint_first_index_offset_fuzzer)
+  add_tint_fuzzer(tint_inspector_fuzzer)
   add_tint_fuzzer(tint_wgsl_reader_spv_writer_fuzzer)
 endif()
 
diff --git a/fuzzers/tint_common_fuzzer.cc b/fuzzers/tint_common_fuzzer.cc
index a43ac9a..b47a8a0 100644
--- a/fuzzers/tint_common_fuzzer.cc
+++ b/fuzzers/tint_common_fuzzer.cc
@@ -23,13 +23,13 @@
 namespace fuzzers {
 
 CommonFuzzer::CommonFuzzer(InputFormat input, OutputFormat output)
-    : input_(input), output_(output) {}
+    : input_(input), output_(output), inspector_enabled_(false) {}
 CommonFuzzer::~CommonFuzzer() = default;
 
 int CommonFuzzer::Run(const uint8_t* data, size_t size) {
-  std::unique_ptr<tint::reader::Reader> parser;
+  std::unique_ptr<reader::Reader> parser;
 #if TINT_BUILD_WGSL_READER
-  std::unique_ptr<tint::Source::File> file;
+  std::unique_ptr<Source::File> file;
 #endif  // TINT_BUILD_WGSL_READER
 
   switch (input_) {
@@ -38,8 +38,8 @@
     {
       std::string str(reinterpret_cast<const char*>(data), size);
 
-      file = std::make_unique<tint::Source::File>("test.wgsl", str);
-      parser = std::make_unique<tint::reader::wgsl::Parser>(file.get());
+      file = std::make_unique<Source::File>("test.wgsl", str);
+      parser = std::make_unique<reader::wgsl::Parser>(file.get());
     }
 #endif  // TINT_BUILD_WGSL_READER
     break;
@@ -51,7 +51,7 @@
       std::vector<uint32_t> input(u32Data, u32Data + sizeInU32);
 
       if (input.size() != 0) {
-        parser = std::make_unique<tint::reader::spirv::Parser>(input);
+        parser = std::make_unique<reader::spirv::Parser>(input);
       }
     }
 #endif  // TINT_BUILD_WGSL_READER
@@ -77,16 +77,78 @@
     return 0;
   }
 
-  tint::TypeDeterminer td(&mod);
+  TypeDeterminer td(&mod);
   if (!td.Determine()) {
     return 0;
   }
 
-  tint::Validator v;
+  Validator v;
   if (!v.Validate(&mod)) {
     return 0;
   }
 
+  if (inspector_enabled_) {
+    inspector::Inspector inspector(mod);
+
+    auto entry_points = inspector.GetEntryPoints();
+    if (inspector.has_error()) {
+      return 0;
+    }
+
+    for (auto& ep : entry_points) {
+      auto remapped_name = inspector.GetRemappedNameForEntryPoint(ep.name);
+      if (inspector.has_error()) {
+        return 0;
+      }
+
+      auto constant_ids = inspector.GetConstantIDs();
+      if (inspector.has_error()) {
+        return 0;
+      }
+
+      auto uniform_bindings =
+          inspector.GetUniformBufferResourceBindings(ep.name);
+      if (inspector.has_error()) {
+        return 0;
+      }
+
+      auto storage_bindings =
+          inspector.GetStorageBufferResourceBindings(ep.name);
+      if (inspector.has_error()) {
+        return 0;
+      }
+
+      auto readonly_bindings =
+          inspector.GetReadOnlyStorageBufferResourceBindings(ep.name);
+      if (inspector.has_error()) {
+        return 0;
+      }
+
+      auto sampler_bindings = inspector.GetSamplerResourceBindings(ep.name);
+      if (inspector.has_error()) {
+        return 0;
+      }
+
+      auto comparison_sampler_bindings =
+          inspector.GetComparisonSamplerResourceBindings(ep.name);
+      if (inspector.has_error()) {
+        return 0;
+      }
+
+      auto sampled_texture_bindings =
+          inspector.GetSampledTextureResourceBindings(ep.name);
+      if (inspector.has_error()) {
+        return 0;
+      }
+
+      auto multisampled_texture_bindings =
+          inspector.GetMultisampledTextureResourceBindings(ep.name);
+      if (inspector.has_error()) {
+        return 0;
+      }
+    }
+  }
+
   if (transform_manager_) {
     auto out = transform_manager_->Run(&mod);
     if (out.diagnostics.contains_errors()) {
@@ -96,27 +158,27 @@
     mod = std::move(out.module);
   }
 
-  std::unique_ptr<tint::writer::Writer> writer;
+  std::unique_ptr<writer::Writer> writer;
 
   switch (output_) {
     case OutputFormat::kWGSL:
 #if TINT_BUILD_WGSL_WRITER
-      writer = std::make_unique<tint::writer::wgsl::Generator>(std::move(mod));
+      writer = std::make_unique<writer::wgsl::Generator>(std::move(mod));
 #endif  // TINT_BUILD_WGSL_WRITER
       break;
     case OutputFormat::kSpv:
 #if TINT_BUILD_SPV_WRITER
-      writer = std::make_unique<tint::writer::spirv::Generator>(std::move(mod));
+      writer = std::make_unique<writer::spirv::Generator>(std::move(mod));
 #endif  // TINT_BUILD_SPV_WRITER
       break;
     case OutputFormat::kHLSL:
 #if TINT_BUILD_HLSL_WRITER
-      writer = std::make_unique<tint::writer::hlsl::Generator>(std::move(mod));
+      writer = std::make_unique<writer::hlsl::Generator>(std::move(mod));
 #endif  // TINT_BUILD_HLSL_WRITER
       break;
     case OutputFormat::kMSL:
 #if TINT_BUILD_MSL_WRITER
-      writer = std::make_unique<tint::writer::msl::Generator>(std::move(mod));
+      writer = std::make_unique<writer::msl::Generator>(std::move(mod));
 #endif  // TINT_BUILD_MSL_WRITER
       break;
     case OutputFormat::kNone:
diff --git a/fuzzers/tint_common_fuzzer.h b/fuzzers/tint_common_fuzzer.h
index 346132d..5f2bcff 100644
--- a/fuzzers/tint_common_fuzzer.h
+++ b/fuzzers/tint_common_fuzzer.h
@@ -30,6 +30,7 @@
   ~CommonFuzzer();
 
   void SetTransformManager(transform::Manager* tm) { transform_manager_ = tm; }
+  void EnableInspector() { inspector_enabled_ = true; }
 
   int Run(const uint8_t* data, size_t size);
 
@@ -37,6 +38,7 @@
   InputFormat input_;
   OutputFormat output_;
   transform::Manager* transform_manager_;
+  bool inspector_enabled_;
 };
 
 }  // namespace fuzzers