Add tests derived from VK-GL-CTS

This adds SPIR-V assembly and WGSL tests derived from VK-GL-CTS commit
571256871c2e2f03995373e1e4a02958d8cd8cf5. The following procedure was
followed:

- Those .amber files in VK-GL-CTS wholly owned by Google were
  identified

- All GLSL and SPIR-V shaders were extracted from the Amber files and
  converted into SPIR-V binaries

- The compact-ids pass of spirv-opt was applied to each binary

- Duplicate binaries were removed

- spirv-opt -O was used to obtain an optimized version of each remaining
  binary, with duplicates discarded

- Binaries that failed validation using spirv-val with target
  environment SPIR-V 1.3 were discarded

- Those binaries that tint could not successfully convert into WGSL were
  put aside for further investigation

- SPIR-V assembly versions of the remaining binaries are included in
  this CL

- test-runner with -generate-expected and -generate-skip was used to
  generate expected .spvasm, .msl, .hlsl and .wgsl outputs for these
  SPIR-V assembly tests

- Each successfully-generated .expected.wgsl is included in this CL
  again, as a WGLSL test

- test-runner with -generate-expected and -generate-skip was used again,
  to generate expected outputs for these WGSL tests

Change-Id: Ibe9baf2729cf97e0b633db9a426f53362a5de540
Reviewed-on: https://dawn-review.googlesource.com/c/tint/+/58842
Kokoro: Kokoro <noreply+kokoro@google.com>
Commit-Queue: Ben Clayton <bclayton@google.com>
Reviewed-by: Ben Clayton <bclayton@google.com>
diff --git a/test/vk-gl-cts/graphicsfuzz/cov-value-tracking-apint-inst-combine-simplify-one-mod-loop-iterator/0-opt.spvasm b/test/vk-gl-cts/graphicsfuzz/cov-value-tracking-apint-inst-combine-simplify-one-mod-loop-iterator/0-opt.spvasm
new file mode 100644
index 0000000..5730c8b
--- /dev/null
+++ b/test/vk-gl-cts/graphicsfuzz/cov-value-tracking-apint-inst-combine-simplify-one-mod-loop-iterator/0-opt.spvasm
@@ -0,0 +1,112 @@
+               OpCapability Shader
+          %1 = OpExtInstImport "GLSL.std.450"
+               OpMemoryModel Logical GLSL450
+               OpEntryPoint Fragment %main "main" %_GLF_color
+               OpExecutionMode %main OriginUpperLeft
+               OpSource ESSL 310
+               OpName %main "main"
+               OpName %a "a"
+               OpName %buf0 "buf0"
+               OpMemberName %buf0 0 "_GLF_uniform_int_values"
+               OpName %_ ""
+               OpName %i "i"
+               OpName %_GLF_color "_GLF_color"
+               OpDecorate %_arr_int_uint_4 ArrayStride 16
+               OpMemberDecorate %buf0 0 Offset 0
+               OpDecorate %buf0 Block
+               OpDecorate %_ DescriptorSet 0
+               OpDecorate %_ Binding 0
+               OpDecorate %_GLF_color Location 0
+       %void = OpTypeVoid
+         %10 = OpTypeFunction %void
+        %int = OpTypeInt 32 1
+%_ptr_Function_int = OpTypePointer Function %int
+       %uint = OpTypeInt 32 0
+     %uint_4 = OpConstant %uint 4
+%_arr_int_uint_4 = OpTypeArray %int %uint_4
+       %buf0 = OpTypeStruct %_arr_int_uint_4
+%_ptr_Uniform_buf0 = OpTypePointer Uniform %buf0
+          %_ = OpVariable %_ptr_Uniform_buf0 Uniform
+      %int_0 = OpConstant %int 0
+      %int_2 = OpConstant %int 2
+%_ptr_Uniform_int = OpTypePointer Uniform %int
+      %int_3 = OpConstant %int 3
+       %bool = OpTypeBool
+      %int_1 = OpConstant %int 1
+      %float = OpTypeFloat 32
+    %v4float = OpTypeVector %float 4
+%_ptr_Output_v4float = OpTypePointer Output %v4float
+ %_GLF_color = OpVariable %_ptr_Output_v4float Output
+       %main = OpFunction %void None %10
+         %25 = OpLabel
+          %a = OpVariable %_ptr_Function_int Function
+          %i = OpVariable %_ptr_Function_int Function
+         %26 = OpAccessChain %_ptr_Uniform_int %_ %int_0 %int_2
+         %27 = OpLoad %int %26
+               OpStore %a %27
+         %28 = OpAccessChain %_ptr_Uniform_int %_ %int_0 %int_3
+         %29 = OpLoad %int %28
+               OpStore %i %29
+               OpBranch %30
+         %30 = OpLabel
+               OpLoopMerge %31 %32 None
+               OpBranch %33
+         %33 = OpLabel
+         %34 = OpLoad %int %i
+         %35 = OpAccessChain %_ptr_Uniform_int %_ %int_0 %int_0
+         %36 = OpLoad %int %35
+         %37 = OpSLessThan %bool %34 %36
+               OpBranchConditional %37 %38 %31
+         %38 = OpLabel
+         %39 = OpLoad %int %i
+         %40 = OpSMod %int %int_1 %39
+         %41 = OpAccessChain %_ptr_Uniform_int %_ %int_0 %int_2
+         %42 = OpLoad %int %41
+         %43 = OpIEqual %bool %40 %42
+               OpSelectionMerge %44 None
+               OpBranchConditional %43 %45 %44
+         %45 = OpLabel
+               OpBranch %32
+         %44 = OpLabel
+         %46 = OpLoad %int %a
+         %47 = OpIAdd %int %46 %int_1
+               OpStore %a %47
+               OpBranch %32
+         %32 = OpLabel
+         %48 = OpLoad %int %i
+         %49 = OpIAdd %int %48 %int_1
+               OpStore %i %49
+               OpBranch %30
+         %31 = OpLabel
+         %50 = OpLoad %int %a
+         %51 = OpAccessChain %_ptr_Uniform_int %_ %int_0 %int_1
+         %52 = OpLoad %int %51
+         %53 = OpIEqual %bool %50 %52
+               OpSelectionMerge %54 None
+               OpBranchConditional %53 %55 %56
+         %55 = OpLabel
+         %57 = OpAccessChain %_ptr_Uniform_int %_ %int_0 %int_3
+         %58 = OpLoad %int %57
+         %59 = OpConvertSToF %float %58
+         %60 = OpAccessChain %_ptr_Uniform_int %_ %int_0 %int_2
+         %61 = OpLoad %int %60
+         %62 = OpConvertSToF %float %61
+         %63 = OpAccessChain %_ptr_Uniform_int %_ %int_0 %int_2
+         %64 = OpLoad %int %63
+         %65 = OpConvertSToF %float %64
+         %66 = OpAccessChain %_ptr_Uniform_int %_ %int_0 %int_3
+         %67 = OpLoad %int %66
+         %68 = OpConvertSToF %float %67
+         %69 = OpCompositeConstruct %v4float %59 %62 %65 %68
+               OpStore %_GLF_color %69
+               OpBranch %54
+         %56 = OpLabel
+         %70 = OpAccessChain %_ptr_Uniform_int %_ %int_0 %int_2
+         %71 = OpLoad %int %70
+         %72 = OpConvertSToF %float %71
+         %73 = OpCompositeConstruct %v4float %72 %72 %72 %72
+               OpStore %_GLF_color %73
+               OpBranch %54
+         %54 = OpLabel
+               OpReturn
+               OpFunctionEnd
diff --git a/test/vk-gl-cts/graphicsfuzz/cov-value-tracking-apint-inst-combine-simplify-one-mod-loop-iterator/0-opt.spvasm.expected.hlsl b/test/vk-gl-cts/graphicsfuzz/cov-value-tracking-apint-inst-combine-simplify-one-mod-loop-iterator/0-opt.spvasm.expected.hlsl
new file mode 100644
index 0000000..ad949e0
--- /dev/null
+++ b/test/vk-gl-cts/graphicsfuzz/cov-value-tracking-apint-inst-combine-simplify-one-mod-loop-iterator/0-opt.spvasm.expected.hlsl
@@ -0,0 +1,62 @@
+cbuffer cbuffer_x_6 : register(b0, space0) {
+  uint4 x_6[4];
+};
+static float4 x_GLF_color = float4(0.0f, 0.0f, 0.0f, 0.0f);
+
+void main_1() {
+  int a = 0;
+  int i = 0;
+  const int x_27 = asint(x_6[2].x);
+  a = x_27;
+  const int x_29 = asint(x_6[3].x);
+  i = x_29;
+  while (true) {
+    const int x_34 = i;
+    const uint scalar_offset = ((16u * uint(0))) / 4;
+    const int x_36 = asint(x_6[scalar_offset / 4][scalar_offset % 4]);
+    if ((x_34 < x_36)) {
+    } else {
+      break;
+    }
+    const int x_39 = i;
+    const int x_42 = asint(x_6[2].x);
+    if (((1 % x_39) == x_42)) {
+      {
+        i = (i + 1);
+      }
+      continue;
+    }
+    a = (a + 1);
+    {
+      i = (i + 1);
+    }
+  }
+  const int x_50 = a;
+  const int x_52 = asint(x_6[1].x);
+  if ((x_50 == x_52)) {
+    const int x_58 = asint(x_6[3].x);
+    const int x_61 = asint(x_6[2].x);
+    const int x_64 = asint(x_6[2].x);
+    const int x_67 = asint(x_6[3].x);
+    x_GLF_color = float4(float(x_58), float(x_61), float(x_64), float(x_67));
+  } else {
+    const int x_71 = asint(x_6[2].x);
+    const float x_72 = float(x_71);
+    x_GLF_color = float4(x_72, x_72, x_72, x_72);
+  }
+  return;
+}
+
+struct main_out {
+  float4 x_GLF_color_1;
+};
+struct tint_symbol {
+  float4 x_GLF_color_1 : SV_Target0;
+};
+
+tint_symbol main() {
+  main_1();
+  const main_out tint_symbol_1 = {x_GLF_color};
+  const tint_symbol tint_symbol_3 = {tint_symbol_1.x_GLF_color_1};
+  return tint_symbol_3;
+}
diff --git a/test/vk-gl-cts/graphicsfuzz/cov-value-tracking-apint-inst-combine-simplify-one-mod-loop-iterator/0-opt.spvasm.expected.msl b/test/vk-gl-cts/graphicsfuzz/cov-value-tracking-apint-inst-combine-simplify-one-mod-loop-iterator/0-opt.spvasm.expected.msl
new file mode 100644
index 0000000..bd9b04a
--- /dev/null
+++ b/test/vk-gl-cts/graphicsfuzz/cov-value-tracking-apint-inst-combine-simplify-one-mod-loop-iterator/0-opt.spvasm.expected.msl
@@ -0,0 +1,74 @@
+#include <metal_stdlib>
+
+using namespace metal;
+struct tint_padded_array_element {
+  /* 0x0000 */ int el;
+  /* 0x0004 */ int8_t tint_pad[12];
+};
+struct tint_array_wrapper {
+  /* 0x0000 */ tint_padded_array_element arr[4];
+};
+struct buf0 {
+  /* 0x0000 */ tint_array_wrapper x_GLF_uniform_int_values;
+};
+struct main_out {
+  float4 x_GLF_color_1;
+};
+struct tint_symbol_1 {
+  float4 x_GLF_color_1 [[color(0)]];
+};
+
+void main_1(constant buf0& x_6, thread float4* const tint_symbol_4) {
+  int a = 0;
+  int i = 0;
+  int const x_27 = x_6.x_GLF_uniform_int_values.arr[2].el;
+  a = x_27;
+  int const x_29 = x_6.x_GLF_uniform_int_values.arr[3].el;
+  i = x_29;
+  while (true) {
+    int const x_34 = i;
+    int const x_36 = x_6.x_GLF_uniform_int_values.arr[0].el;
+    if ((x_34 < x_36)) {
+    } else {
+      break;
+    }
+    int const x_39 = i;
+    int const x_42 = x_6.x_GLF_uniform_int_values.arr[2].el;
+    if (((1 % x_39) == x_42)) {
+      {
+        int const x_48 = i;
+        i = (x_48 + 1);
+      }
+      continue;
+    }
+    int const x_46 = a;
+    a = (x_46 + 1);
+    {
+      int const x_48 = i;
+      i = (x_48 + 1);
+    }
+  }
+  int const x_50 = a;
+  int const x_52 = x_6.x_GLF_uniform_int_values.arr[1].el;
+  if ((x_50 == x_52)) {
+    int const x_58 = x_6.x_GLF_uniform_int_values.arr[3].el;
+    int const x_61 = x_6.x_GLF_uniform_int_values.arr[2].el;
+    int const x_64 = x_6.x_GLF_uniform_int_values.arr[2].el;
+    int const x_67 = x_6.x_GLF_uniform_int_values.arr[3].el;
+    *(tint_symbol_4) = float4(float(x_58), float(x_61), float(x_64), float(x_67));
+  } else {
+    int const x_71 = x_6.x_GLF_uniform_int_values.arr[2].el;
+    float const x_72 = float(x_71);
+    *(tint_symbol_4) = float4(x_72, x_72, x_72, x_72);
+  }
+  return;
+}
+
+fragment tint_symbol_1 tint_symbol(constant buf0& x_6 [[buffer(0)]]) {
+  thread float4 tint_symbol_5 = 0.0f;
+  main_1(x_6, &(tint_symbol_5));
+  main_out const tint_symbol_2 = {.x_GLF_color_1=tint_symbol_5};
+  tint_symbol_1 const tint_symbol_3 = {.x_GLF_color_1=tint_symbol_2.x_GLF_color_1};
+  return tint_symbol_3;
+}
+
diff --git a/test/vk-gl-cts/graphicsfuzz/cov-value-tracking-apint-inst-combine-simplify-one-mod-loop-iterator/0-opt.spvasm.expected.spvasm b/test/vk-gl-cts/graphicsfuzz/cov-value-tracking-apint-inst-combine-simplify-one-mod-loop-iterator/0-opt.spvasm.expected.spvasm
new file mode 100644
index 0000000..815ee58
--- /dev/null
+++ b/test/vk-gl-cts/graphicsfuzz/cov-value-tracking-apint-inst-combine-simplify-one-mod-loop-iterator/0-opt.spvasm.expected.spvasm
@@ -0,0 +1,150 @@
+; SPIR-V
+; Version: 1.3
+; Generator: Google Tint Compiler; 0
+; Bound: 92
+; Schema: 0
+               OpCapability Shader
+               OpMemoryModel Logical GLSL450
+               OpEntryPoint Fragment %main "main" %tint_symbol_1
+               OpExecutionMode %main OriginUpperLeft
+               OpName %buf0 "buf0"
+               OpMemberName %buf0 0 "x_GLF_uniform_int_values"
+               OpName %x_6 "x_6"
+               OpName %x_GLF_color "x_GLF_color"
+               OpName %tint_symbol_1 "tint_symbol_1"
+               OpName %main_1 "main_1"
+               OpName %a "a"
+               OpName %i "i"
+               OpName %main_out "main_out"
+               OpMemberName %main_out 0 "x_GLF_color_1"
+               OpName %tint_symbol_2 "tint_symbol_2"
+               OpName %tint_symbol "tint_symbol"
+               OpName %main "main"
+               OpDecorate %buf0 Block
+               OpMemberDecorate %buf0 0 Offset 0
+               OpDecorate %_arr_int_uint_4 ArrayStride 16
+               OpDecorate %x_6 NonWritable
+               OpDecorate %x_6 DescriptorSet 0
+               OpDecorate %x_6 Binding 0
+               OpDecorate %tint_symbol_1 Location 0
+               OpMemberDecorate %main_out 0 Offset 0
+        %int = OpTypeInt 32 1
+       %uint = OpTypeInt 32 0
+     %uint_4 = OpConstant %uint 4
+%_arr_int_uint_4 = OpTypeArray %int %uint_4
+       %buf0 = OpTypeStruct %_arr_int_uint_4
+%_ptr_Uniform_buf0 = OpTypePointer Uniform %buf0
+        %x_6 = OpVariable %_ptr_Uniform_buf0 Uniform
+      %float = OpTypeFloat 32
+    %v4float = OpTypeVector %float 4
+%_ptr_Private_v4float = OpTypePointer Private %v4float
+         %12 = OpConstantNull %v4float
+%x_GLF_color = OpVariable %_ptr_Private_v4float Private %12
+%_ptr_Output_v4float = OpTypePointer Output %v4float
+%tint_symbol_1 = OpVariable %_ptr_Output_v4float Output %12
+       %void = OpTypeVoid
+         %15 = OpTypeFunction %void
+%_ptr_Function_int = OpTypePointer Function %int
+         %21 = OpConstantNull %int
+     %uint_0 = OpConstant %uint 0
+      %int_2 = OpConstant %int 2
+%_ptr_Uniform_int = OpTypePointer Uniform %int
+      %int_3 = OpConstant %int 3
+      %int_0 = OpConstant %int 0
+       %bool = OpTypeBool
+      %int_1 = OpConstant %int 1
+   %main_out = OpTypeStruct %v4float
+         %80 = OpTypeFunction %void %main_out
+     %main_1 = OpFunction %void None %15
+         %18 = OpLabel
+          %a = OpVariable %_ptr_Function_int Function %21
+          %i = OpVariable %_ptr_Function_int Function %21
+         %26 = OpAccessChain %_ptr_Uniform_int %x_6 %uint_0 %int_2
+         %27 = OpLoad %int %26
+               OpStore %a %27
+         %29 = OpAccessChain %_ptr_Uniform_int %x_6 %uint_0 %int_3
+         %30 = OpLoad %int %29
+               OpStore %i %30
+               OpBranch %31
+         %31 = OpLabel
+               OpLoopMerge %32 %33 None
+               OpBranch %34
+         %34 = OpLabel
+         %35 = OpLoad %int %i
+         %37 = OpAccessChain %_ptr_Uniform_int %x_6 %uint_0 %int_0
+         %38 = OpLoad %int %37
+         %39 = OpSLessThan %bool %35 %38
+               OpSelectionMerge %41 None
+               OpBranchConditional %39 %42 %43
+         %42 = OpLabel
+               OpBranch %41
+         %43 = OpLabel
+               OpBranch %32
+         %41 = OpLabel
+         %44 = OpLoad %int %i
+         %45 = OpAccessChain %_ptr_Uniform_int %x_6 %uint_0 %int_2
+         %46 = OpLoad %int %45
+         %48 = OpSMod %int %int_1 %44
+         %49 = OpIEqual %bool %48 %46
+               OpSelectionMerge %50 None
+               OpBranchConditional %49 %51 %50
+         %51 = OpLabel
+               OpBranch %33
+         %50 = OpLabel
+         %52 = OpLoad %int %a
+         %53 = OpIAdd %int %52 %int_1
+               OpStore %a %53
+               OpBranch %33
+         %33 = OpLabel
+         %54 = OpLoad %int %i
+         %55 = OpIAdd %int %54 %int_1
+               OpStore %i %55
+               OpBranch %31
+         %32 = OpLabel
+         %56 = OpLoad %int %a
+         %57 = OpAccessChain %_ptr_Uniform_int %x_6 %uint_0 %int_1
+         %58 = OpLoad %int %57
+         %59 = OpIEqual %bool %56 %58
+               OpSelectionMerge %60 None
+               OpBranchConditional %59 %61 %62
+         %61 = OpLabel
+         %63 = OpAccessChain %_ptr_Uniform_int %x_6 %uint_0 %int_3
+         %64 = OpLoad %int %63
+         %65 = OpAccessChain %_ptr_Uniform_int %x_6 %uint_0 %int_2
+         %66 = OpLoad %int %65
+         %67 = OpAccessChain %_ptr_Uniform_int %x_6 %uint_0 %int_2
+         %68 = OpLoad %int %67
+         %69 = OpAccessChain %_ptr_Uniform_int %x_6 %uint_0 %int_3
+         %70 = OpLoad %int %69
+         %71 = OpConvertSToF %float %64
+         %72 = OpConvertSToF %float %66
+         %73 = OpConvertSToF %float %68
+         %74 = OpConvertSToF %float %70
+         %75 = OpCompositeConstruct %v4float %71 %72 %73 %74
+               OpStore %x_GLF_color %75
+               OpBranch %60
+         %62 = OpLabel
+         %76 = OpAccessChain %_ptr_Uniform_int %x_6 %uint_0 %int_2
+         %77 = OpLoad %int %76
+         %78 = OpConvertSToF %float %77
+         %79 = OpCompositeConstruct %v4float %78 %78 %78 %78
+               OpStore %x_GLF_color %79
+               OpBranch %60
+         %60 = OpLabel
+               OpReturn
+               OpFunctionEnd
+%tint_symbol_2 = OpFunction %void None %80
+%tint_symbol = OpFunctionParameter %main_out
+         %84 = OpLabel
+         %85 = OpCompositeExtract %v4float %tint_symbol 0
+               OpStore %tint_symbol_1 %85
+               OpReturn
+               OpFunctionEnd
+       %main = OpFunction %void None %15
+         %87 = OpLabel
+         %88 = OpFunctionCall %void %main_1
+         %90 = OpLoad %v4float %x_GLF_color
+         %91 = OpCompositeConstruct %main_out %90
+         %89 = OpFunctionCall %void %tint_symbol_2 %91
+               OpReturn
+               OpFunctionEnd
diff --git a/test/vk-gl-cts/graphicsfuzz/cov-value-tracking-apint-inst-combine-simplify-one-mod-loop-iterator/0-opt.spvasm.expected.wgsl b/test/vk-gl-cts/graphicsfuzz/cov-value-tracking-apint-inst-combine-simplify-one-mod-loop-iterator/0-opt.spvasm.expected.wgsl
new file mode 100644
index 0000000..d11bb08
--- /dev/null
+++ b/test/vk-gl-cts/graphicsfuzz/cov-value-tracking-apint-inst-combine-simplify-one-mod-loop-iterator/0-opt.spvasm.expected.wgsl
@@ -0,0 +1,64 @@
+type Arr = [[stride(16)]] array<i32, 4>;
+
+[[block]]
+struct buf0 {
+  x_GLF_uniform_int_values : Arr;
+};
+
+[[group(0), binding(0)]] var<uniform> x_6 : buf0;
+
+var<private> x_GLF_color : vec4<f32>;
+
+fn main_1() {
+  var a : i32;
+  var i : i32;
+  let x_27 : i32 = x_6.x_GLF_uniform_int_values[2];
+  a = x_27;
+  let x_29 : i32 = x_6.x_GLF_uniform_int_values[3];
+  i = x_29;
+  loop {
+    let x_34 : i32 = i;
+    let x_36 : i32 = x_6.x_GLF_uniform_int_values[0];
+    if ((x_34 < x_36)) {
+    } else {
+      break;
+    }
+    let x_39 : i32 = i;
+    let x_42 : i32 = x_6.x_GLF_uniform_int_values[2];
+    if (((1 % x_39) == x_42)) {
+      continue;
+    }
+    let x_46 : i32 = a;
+    a = (x_46 + 1);
+
+    continuing {
+      let x_48 : i32 = i;
+      i = (x_48 + 1);
+    }
+  }
+  let x_50 : i32 = a;
+  let x_52 : i32 = x_6.x_GLF_uniform_int_values[1];
+  if ((x_50 == x_52)) {
+    let x_58 : i32 = x_6.x_GLF_uniform_int_values[3];
+    let x_61 : i32 = x_6.x_GLF_uniform_int_values[2];
+    let x_64 : i32 = x_6.x_GLF_uniform_int_values[2];
+    let x_67 : i32 = x_6.x_GLF_uniform_int_values[3];
+    x_GLF_color = vec4<f32>(f32(x_58), f32(x_61), f32(x_64), f32(x_67));
+  } else {
+    let x_71 : i32 = x_6.x_GLF_uniform_int_values[2];
+    let x_72 : f32 = f32(x_71);
+    x_GLF_color = vec4<f32>(x_72, x_72, x_72, x_72);
+  }
+  return;
+}
+
+struct main_out {
+  [[location(0)]]
+  x_GLF_color_1 : vec4<f32>;
+};
+
+[[stage(fragment)]]
+fn main() -> main_out {
+  main_1();
+  return main_out(x_GLF_color);
+}
diff --git a/test/vk-gl-cts/graphicsfuzz/cov-value-tracking-apint-inst-combine-simplify-one-mod-loop-iterator/0-opt.wgsl b/test/vk-gl-cts/graphicsfuzz/cov-value-tracking-apint-inst-combine-simplify-one-mod-loop-iterator/0-opt.wgsl
new file mode 100644
index 0000000..d11bb08
--- /dev/null
+++ b/test/vk-gl-cts/graphicsfuzz/cov-value-tracking-apint-inst-combine-simplify-one-mod-loop-iterator/0-opt.wgsl
@@ -0,0 +1,64 @@
+type Arr = [[stride(16)]] array<i32, 4>;
+
+[[block]]
+struct buf0 {
+  x_GLF_uniform_int_values : Arr;
+};
+
+[[group(0), binding(0)]] var<uniform> x_6 : buf0;
+
+var<private> x_GLF_color : vec4<f32>;
+
+fn main_1() {
+  var a : i32;
+  var i : i32;
+  let x_27 : i32 = x_6.x_GLF_uniform_int_values[2];
+  a = x_27;
+  let x_29 : i32 = x_6.x_GLF_uniform_int_values[3];
+  i = x_29;
+  loop {
+    let x_34 : i32 = i;
+    let x_36 : i32 = x_6.x_GLF_uniform_int_values[0];
+    if ((x_34 < x_36)) {
+    } else {
+      break;
+    }
+    let x_39 : i32 = i;
+    let x_42 : i32 = x_6.x_GLF_uniform_int_values[2];
+    if (((1 % x_39) == x_42)) {
+      continue;
+    }
+    let x_46 : i32 = a;
+    a = (x_46 + 1);
+
+    continuing {
+      let x_48 : i32 = i;
+      i = (x_48 + 1);
+    }
+  }
+  let x_50 : i32 = a;
+  let x_52 : i32 = x_6.x_GLF_uniform_int_values[1];
+  if ((x_50 == x_52)) {
+    let x_58 : i32 = x_6.x_GLF_uniform_int_values[3];
+    let x_61 : i32 = x_6.x_GLF_uniform_int_values[2];
+    let x_64 : i32 = x_6.x_GLF_uniform_int_values[2];
+    let x_67 : i32 = x_6.x_GLF_uniform_int_values[3];
+    x_GLF_color = vec4<f32>(f32(x_58), f32(x_61), f32(x_64), f32(x_67));
+  } else {
+    let x_71 : i32 = x_6.x_GLF_uniform_int_values[2];
+    let x_72 : f32 = f32(x_71);
+    x_GLF_color = vec4<f32>(x_72, x_72, x_72, x_72);
+  }
+  return;
+}
+
+struct main_out {
+  [[location(0)]]
+  x_GLF_color_1 : vec4<f32>;
+};
+
+[[stage(fragment)]]
+fn main() -> main_out {
+  main_1();
+  return main_out(x_GLF_color);
+}
diff --git a/test/vk-gl-cts/graphicsfuzz/cov-value-tracking-apint-inst-combine-simplify-one-mod-loop-iterator/0-opt.wgsl.expected.hlsl b/test/vk-gl-cts/graphicsfuzz/cov-value-tracking-apint-inst-combine-simplify-one-mod-loop-iterator/0-opt.wgsl.expected.hlsl
new file mode 100644
index 0000000..ad949e0
--- /dev/null
+++ b/test/vk-gl-cts/graphicsfuzz/cov-value-tracking-apint-inst-combine-simplify-one-mod-loop-iterator/0-opt.wgsl.expected.hlsl
@@ -0,0 +1,62 @@
+cbuffer cbuffer_x_6 : register(b0, space0) {
+  uint4 x_6[4];
+};
+static float4 x_GLF_color = float4(0.0f, 0.0f, 0.0f, 0.0f);
+
+void main_1() {
+  int a = 0;
+  int i = 0;
+  const int x_27 = asint(x_6[2].x);
+  a = x_27;
+  const int x_29 = asint(x_6[3].x);
+  i = x_29;
+  while (true) {
+    const int x_34 = i;
+    const uint scalar_offset = ((16u * uint(0))) / 4;
+    const int x_36 = asint(x_6[scalar_offset / 4][scalar_offset % 4]);
+    if ((x_34 < x_36)) {
+    } else {
+      break;
+    }
+    const int x_39 = i;
+    const int x_42 = asint(x_6[2].x);
+    if (((1 % x_39) == x_42)) {
+      {
+        i = (i + 1);
+      }
+      continue;
+    }
+    a = (a + 1);
+    {
+      i = (i + 1);
+    }
+  }
+  const int x_50 = a;
+  const int x_52 = asint(x_6[1].x);
+  if ((x_50 == x_52)) {
+    const int x_58 = asint(x_6[3].x);
+    const int x_61 = asint(x_6[2].x);
+    const int x_64 = asint(x_6[2].x);
+    const int x_67 = asint(x_6[3].x);
+    x_GLF_color = float4(float(x_58), float(x_61), float(x_64), float(x_67));
+  } else {
+    const int x_71 = asint(x_6[2].x);
+    const float x_72 = float(x_71);
+    x_GLF_color = float4(x_72, x_72, x_72, x_72);
+  }
+  return;
+}
+
+struct main_out {
+  float4 x_GLF_color_1;
+};
+struct tint_symbol {
+  float4 x_GLF_color_1 : SV_Target0;
+};
+
+tint_symbol main() {
+  main_1();
+  const main_out tint_symbol_1 = {x_GLF_color};
+  const tint_symbol tint_symbol_3 = {tint_symbol_1.x_GLF_color_1};
+  return tint_symbol_3;
+}
diff --git a/test/vk-gl-cts/graphicsfuzz/cov-value-tracking-apint-inst-combine-simplify-one-mod-loop-iterator/0-opt.wgsl.expected.msl b/test/vk-gl-cts/graphicsfuzz/cov-value-tracking-apint-inst-combine-simplify-one-mod-loop-iterator/0-opt.wgsl.expected.msl
new file mode 100644
index 0000000..bd9b04a
--- /dev/null
+++ b/test/vk-gl-cts/graphicsfuzz/cov-value-tracking-apint-inst-combine-simplify-one-mod-loop-iterator/0-opt.wgsl.expected.msl
@@ -0,0 +1,74 @@
+#include <metal_stdlib>
+
+using namespace metal;
+struct tint_padded_array_element {
+  /* 0x0000 */ int el;
+  /* 0x0004 */ int8_t tint_pad[12];
+};
+struct tint_array_wrapper {
+  /* 0x0000 */ tint_padded_array_element arr[4];
+};
+struct buf0 {
+  /* 0x0000 */ tint_array_wrapper x_GLF_uniform_int_values;
+};
+struct main_out {
+  float4 x_GLF_color_1;
+};
+struct tint_symbol_1 {
+  float4 x_GLF_color_1 [[color(0)]];
+};
+
+void main_1(constant buf0& x_6, thread float4* const tint_symbol_4) {
+  int a = 0;
+  int i = 0;
+  int const x_27 = x_6.x_GLF_uniform_int_values.arr[2].el;
+  a = x_27;
+  int const x_29 = x_6.x_GLF_uniform_int_values.arr[3].el;
+  i = x_29;
+  while (true) {
+    int const x_34 = i;
+    int const x_36 = x_6.x_GLF_uniform_int_values.arr[0].el;
+    if ((x_34 < x_36)) {
+    } else {
+      break;
+    }
+    int const x_39 = i;
+    int const x_42 = x_6.x_GLF_uniform_int_values.arr[2].el;
+    if (((1 % x_39) == x_42)) {
+      {
+        int const x_48 = i;
+        i = (x_48 + 1);
+      }
+      continue;
+    }
+    int const x_46 = a;
+    a = (x_46 + 1);
+    {
+      int const x_48 = i;
+      i = (x_48 + 1);
+    }
+  }
+  int const x_50 = a;
+  int const x_52 = x_6.x_GLF_uniform_int_values.arr[1].el;
+  if ((x_50 == x_52)) {
+    int const x_58 = x_6.x_GLF_uniform_int_values.arr[3].el;
+    int const x_61 = x_6.x_GLF_uniform_int_values.arr[2].el;
+    int const x_64 = x_6.x_GLF_uniform_int_values.arr[2].el;
+    int const x_67 = x_6.x_GLF_uniform_int_values.arr[3].el;
+    *(tint_symbol_4) = float4(float(x_58), float(x_61), float(x_64), float(x_67));
+  } else {
+    int const x_71 = x_6.x_GLF_uniform_int_values.arr[2].el;
+    float const x_72 = float(x_71);
+    *(tint_symbol_4) = float4(x_72, x_72, x_72, x_72);
+  }
+  return;
+}
+
+fragment tint_symbol_1 tint_symbol(constant buf0& x_6 [[buffer(0)]]) {
+  thread float4 tint_symbol_5 = 0.0f;
+  main_1(x_6, &(tint_symbol_5));
+  main_out const tint_symbol_2 = {.x_GLF_color_1=tint_symbol_5};
+  tint_symbol_1 const tint_symbol_3 = {.x_GLF_color_1=tint_symbol_2.x_GLF_color_1};
+  return tint_symbol_3;
+}
+
diff --git a/test/vk-gl-cts/graphicsfuzz/cov-value-tracking-apint-inst-combine-simplify-one-mod-loop-iterator/0-opt.wgsl.expected.spvasm b/test/vk-gl-cts/graphicsfuzz/cov-value-tracking-apint-inst-combine-simplify-one-mod-loop-iterator/0-opt.wgsl.expected.spvasm
new file mode 100644
index 0000000..815ee58
--- /dev/null
+++ b/test/vk-gl-cts/graphicsfuzz/cov-value-tracking-apint-inst-combine-simplify-one-mod-loop-iterator/0-opt.wgsl.expected.spvasm
@@ -0,0 +1,150 @@
+; SPIR-V
+; Version: 1.3
+; Generator: Google Tint Compiler; 0
+; Bound: 92
+; Schema: 0
+               OpCapability Shader
+               OpMemoryModel Logical GLSL450
+               OpEntryPoint Fragment %main "main" %tint_symbol_1
+               OpExecutionMode %main OriginUpperLeft
+               OpName %buf0 "buf0"
+               OpMemberName %buf0 0 "x_GLF_uniform_int_values"
+               OpName %x_6 "x_6"
+               OpName %x_GLF_color "x_GLF_color"
+               OpName %tint_symbol_1 "tint_symbol_1"
+               OpName %main_1 "main_1"
+               OpName %a "a"
+               OpName %i "i"
+               OpName %main_out "main_out"
+               OpMemberName %main_out 0 "x_GLF_color_1"
+               OpName %tint_symbol_2 "tint_symbol_2"
+               OpName %tint_symbol "tint_symbol"
+               OpName %main "main"
+               OpDecorate %buf0 Block
+               OpMemberDecorate %buf0 0 Offset 0
+               OpDecorate %_arr_int_uint_4 ArrayStride 16
+               OpDecorate %x_6 NonWritable
+               OpDecorate %x_6 DescriptorSet 0
+               OpDecorate %x_6 Binding 0
+               OpDecorate %tint_symbol_1 Location 0
+               OpMemberDecorate %main_out 0 Offset 0
+        %int = OpTypeInt 32 1
+       %uint = OpTypeInt 32 0
+     %uint_4 = OpConstant %uint 4
+%_arr_int_uint_4 = OpTypeArray %int %uint_4
+       %buf0 = OpTypeStruct %_arr_int_uint_4
+%_ptr_Uniform_buf0 = OpTypePointer Uniform %buf0
+        %x_6 = OpVariable %_ptr_Uniform_buf0 Uniform
+      %float = OpTypeFloat 32
+    %v4float = OpTypeVector %float 4
+%_ptr_Private_v4float = OpTypePointer Private %v4float
+         %12 = OpConstantNull %v4float
+%x_GLF_color = OpVariable %_ptr_Private_v4float Private %12
+%_ptr_Output_v4float = OpTypePointer Output %v4float
+%tint_symbol_1 = OpVariable %_ptr_Output_v4float Output %12
+       %void = OpTypeVoid
+         %15 = OpTypeFunction %void
+%_ptr_Function_int = OpTypePointer Function %int
+         %21 = OpConstantNull %int
+     %uint_0 = OpConstant %uint 0
+      %int_2 = OpConstant %int 2
+%_ptr_Uniform_int = OpTypePointer Uniform %int
+      %int_3 = OpConstant %int 3
+      %int_0 = OpConstant %int 0
+       %bool = OpTypeBool
+      %int_1 = OpConstant %int 1
+   %main_out = OpTypeStruct %v4float
+         %80 = OpTypeFunction %void %main_out
+     %main_1 = OpFunction %void None %15
+         %18 = OpLabel
+          %a = OpVariable %_ptr_Function_int Function %21
+          %i = OpVariable %_ptr_Function_int Function %21
+         %26 = OpAccessChain %_ptr_Uniform_int %x_6 %uint_0 %int_2
+         %27 = OpLoad %int %26
+               OpStore %a %27
+         %29 = OpAccessChain %_ptr_Uniform_int %x_6 %uint_0 %int_3
+         %30 = OpLoad %int %29
+               OpStore %i %30
+               OpBranch %31
+         %31 = OpLabel
+               OpLoopMerge %32 %33 None
+               OpBranch %34
+         %34 = OpLabel
+         %35 = OpLoad %int %i
+         %37 = OpAccessChain %_ptr_Uniform_int %x_6 %uint_0 %int_0
+         %38 = OpLoad %int %37
+         %39 = OpSLessThan %bool %35 %38
+               OpSelectionMerge %41 None
+               OpBranchConditional %39 %42 %43
+         %42 = OpLabel
+               OpBranch %41
+         %43 = OpLabel
+               OpBranch %32
+         %41 = OpLabel
+         %44 = OpLoad %int %i
+         %45 = OpAccessChain %_ptr_Uniform_int %x_6 %uint_0 %int_2
+         %46 = OpLoad %int %45
+         %48 = OpSMod %int %int_1 %44
+         %49 = OpIEqual %bool %48 %46
+               OpSelectionMerge %50 None
+               OpBranchConditional %49 %51 %50
+         %51 = OpLabel
+               OpBranch %33
+         %50 = OpLabel
+         %52 = OpLoad %int %a
+         %53 = OpIAdd %int %52 %int_1
+               OpStore %a %53
+               OpBranch %33
+         %33 = OpLabel
+         %54 = OpLoad %int %i
+         %55 = OpIAdd %int %54 %int_1
+               OpStore %i %55
+               OpBranch %31
+         %32 = OpLabel
+         %56 = OpLoad %int %a
+         %57 = OpAccessChain %_ptr_Uniform_int %x_6 %uint_0 %int_1
+         %58 = OpLoad %int %57
+         %59 = OpIEqual %bool %56 %58
+               OpSelectionMerge %60 None
+               OpBranchConditional %59 %61 %62
+         %61 = OpLabel
+         %63 = OpAccessChain %_ptr_Uniform_int %x_6 %uint_0 %int_3
+         %64 = OpLoad %int %63
+         %65 = OpAccessChain %_ptr_Uniform_int %x_6 %uint_0 %int_2
+         %66 = OpLoad %int %65
+         %67 = OpAccessChain %_ptr_Uniform_int %x_6 %uint_0 %int_2
+         %68 = OpLoad %int %67
+         %69 = OpAccessChain %_ptr_Uniform_int %x_6 %uint_0 %int_3
+         %70 = OpLoad %int %69
+         %71 = OpConvertSToF %float %64
+         %72 = OpConvertSToF %float %66
+         %73 = OpConvertSToF %float %68
+         %74 = OpConvertSToF %float %70
+         %75 = OpCompositeConstruct %v4float %71 %72 %73 %74
+               OpStore %x_GLF_color %75
+               OpBranch %60
+         %62 = OpLabel
+         %76 = OpAccessChain %_ptr_Uniform_int %x_6 %uint_0 %int_2
+         %77 = OpLoad %int %76
+         %78 = OpConvertSToF %float %77
+         %79 = OpCompositeConstruct %v4float %78 %78 %78 %78
+               OpStore %x_GLF_color %79
+               OpBranch %60
+         %60 = OpLabel
+               OpReturn
+               OpFunctionEnd
+%tint_symbol_2 = OpFunction %void None %80
+%tint_symbol = OpFunctionParameter %main_out
+         %84 = OpLabel
+         %85 = OpCompositeExtract %v4float %tint_symbol 0
+               OpStore %tint_symbol_1 %85
+               OpReturn
+               OpFunctionEnd
+       %main = OpFunction %void None %15
+         %87 = OpLabel
+         %88 = OpFunctionCall %void %main_1
+         %90 = OpLoad %v4float %x_GLF_color
+         %91 = OpCompositeConstruct %main_out %90
+         %89 = OpFunctionCall %void %tint_symbol_2 %91
+               OpReturn
+               OpFunctionEnd
diff --git a/test/vk-gl-cts/graphicsfuzz/cov-value-tracking-apint-inst-combine-simplify-one-mod-loop-iterator/0-opt.wgsl.expected.wgsl b/test/vk-gl-cts/graphicsfuzz/cov-value-tracking-apint-inst-combine-simplify-one-mod-loop-iterator/0-opt.wgsl.expected.wgsl
new file mode 100644
index 0000000..d11bb08
--- /dev/null
+++ b/test/vk-gl-cts/graphicsfuzz/cov-value-tracking-apint-inst-combine-simplify-one-mod-loop-iterator/0-opt.wgsl.expected.wgsl
@@ -0,0 +1,64 @@
+type Arr = [[stride(16)]] array<i32, 4>;
+
+[[block]]
+struct buf0 {
+  x_GLF_uniform_int_values : Arr;
+};
+
+[[group(0), binding(0)]] var<uniform> x_6 : buf0;
+
+var<private> x_GLF_color : vec4<f32>;
+
+fn main_1() {
+  var a : i32;
+  var i : i32;
+  let x_27 : i32 = x_6.x_GLF_uniform_int_values[2];
+  a = x_27;
+  let x_29 : i32 = x_6.x_GLF_uniform_int_values[3];
+  i = x_29;
+  loop {
+    let x_34 : i32 = i;
+    let x_36 : i32 = x_6.x_GLF_uniform_int_values[0];
+    if ((x_34 < x_36)) {
+    } else {
+      break;
+    }
+    let x_39 : i32 = i;
+    let x_42 : i32 = x_6.x_GLF_uniform_int_values[2];
+    if (((1 % x_39) == x_42)) {
+      continue;
+    }
+    let x_46 : i32 = a;
+    a = (x_46 + 1);
+
+    continuing {
+      let x_48 : i32 = i;
+      i = (x_48 + 1);
+    }
+  }
+  let x_50 : i32 = a;
+  let x_52 : i32 = x_6.x_GLF_uniform_int_values[1];
+  if ((x_50 == x_52)) {
+    let x_58 : i32 = x_6.x_GLF_uniform_int_values[3];
+    let x_61 : i32 = x_6.x_GLF_uniform_int_values[2];
+    let x_64 : i32 = x_6.x_GLF_uniform_int_values[2];
+    let x_67 : i32 = x_6.x_GLF_uniform_int_values[3];
+    x_GLF_color = vec4<f32>(f32(x_58), f32(x_61), f32(x_64), f32(x_67));
+  } else {
+    let x_71 : i32 = x_6.x_GLF_uniform_int_values[2];
+    let x_72 : f32 = f32(x_71);
+    x_GLF_color = vec4<f32>(x_72, x_72, x_72, x_72);
+  }
+  return;
+}
+
+struct main_out {
+  [[location(0)]]
+  x_GLF_color_1 : vec4<f32>;
+};
+
+[[stage(fragment)]]
+fn main() -> main_out {
+  main_1();
+  return main_out(x_GLF_color);
+}