Reland "Add expectations.txt validation to presubmit"

This is a reland of commit cde5589953

Original change's description:
> Add expectations.txt validation to presubmit
>
> Change-Id: Ibabdfbdf44b027a6e6441e140f23b2c2488f32dc
> Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/112120
> Reviewed-by: Ben Clayton <bclayton@google.com>
> Commit-Queue: Austin Eng <enga@chromium.org>
> Kokoro: Kokoro <noreply+kokoro@google.com>

Change-Id: I013eeec03e27b3147023ea094f5bde011561edd1
Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/113540
Reviewed-by: Ben Clayton <bclayton@google.com>
Commit-Queue: Austin Eng <enga@chromium.org>
Kokoro: Austin Eng <enga@chromium.org>
This commit is contained in:
Austin Eng 2022-12-08 21:57:55 +00:00 committed by Dawn LUCI CQ
parent 31090e3096
commit 100d4bf339
2 changed files with 70 additions and 8 deletions

View File

@ -12,17 +12,24 @@
# See the License for the specific language governing permissions and # See the License for the specific language governing permissions and
# limitations under the License. # limitations under the License.
def go_path(input_api):
go = input_api.os_path.join(input_api.change.RepositoryRoot(), "tools",
"golang", "bin", "go")
if input_api.is_windows:
go += '.exe'
return go
def RunGoTests(input_api, output_api): def RunGoTests(input_api, output_api):
results = [] results = []
try: try:
go = input_api.os_path.join(input_api.change.RepositoryRoot(), "tools", input_api.subprocess.check_call_out(
"golang", "bin", "go") [go_path(input_api), "test", "./..."],
if input_api.is_windows: stdout=input_api.subprocess.PIPE,
go += '.exe' stderr=input_api.subprocess.PIPE,
input_api.subprocess.check_call_out([go, "test", "./..."], cwd=input_api.PresubmitLocalPath())
stdout=input_api.subprocess.PIPE,
stderr=input_api.subprocess.PIPE,
cwd=input_api.PresubmitLocalPath())
except input_api.subprocess.CalledProcessError as e: except input_api.subprocess.CalledProcessError as e:
results.append(output_api.PresubmitError('%s' % (e, ))) results.append(output_api.PresubmitError('%s' % (e, )))
return results return results

55
webgpu-cts/PRESUBMIT.py Normal file
View File

@ -0,0 +1,55 @@
# Copyright 2022 The Dawn & Tint Authors
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
import sys
USE_PYTHON3 = True
def _DoCommonChecks(input_api, output_api):
sys.path += [input_api.change.RepositoryRoot()]
from go_presubmit_support import go_path
results = []
try:
tools_path = input_api.os_path.join(input_api.change.RepositoryRoot(),
'tools')
cts_bin = input_api.os_path.join(tools_path, 'bin', 'cts')
if input_api.is_windows:
cts_bin += '.exe'
cmd = [
go_path(input_api), 'build', '-o', cts_bin,
input_api.os_path.join('.', 'cmd', 'cts')
]
input_api.subprocess.check_call_out(cmd,
stdout=input_api.subprocess.PIPE,
stderr=input_api.subprocess.PIPE,
cwd=input_api.os_path.join(
tools_path, 'src'))
cmd = [cts_bin, 'validate']
input_api.subprocess.check_call_out(
cmd,
stdout=input_api.subprocess.PIPE,
stderr=input_api.subprocess.PIPE,
cwd=input_api.change.RepositoryRoot())
except input_api.subprocess.CalledProcessError as e:
results.append(output_api.PresubmitError('%s' % (e, )))
return results
CheckChangeOnUpload = _DoCommonChecks
CheckChangeOnCommit = _DoCommonChecks