blob: f161443f8088404040710ee3fc9414ec53b1b95e [file] [log] [blame]
# Copyright (c) 2013 The Chromium Authors. All rights reserved.
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.
import os
import re
import sys
def _SyncFilesToCloud(input_api, output_api):
"""Searches for .sha1 files and uploads them to Cloud Storage.
It validates all the hashes and skips upload if not necessary.
"""
# Because this script will be called from a magic PRESUBMIT demon,
# avoid angering it; don't pollute its sys.path.
old_sys_path = sys.path
try:
sys.path = [os.path.join(os.pardir, os.pardir, 'telemetry')] + sys.path
from telemetry.page import cloud_storage
finally:
sys.path = old_sys_path
hashes_in_cloud_storage = cloud_storage.List(cloud_storage.DEFAULT_BUCKET)
results = []
for hash_path in input_api.AbsoluteLocalPaths():
file_path, extension = os.path.splitext(hash_path)
if extension != '.sha1':
continue
with open(hash_path, 'rb') as f:
file_hash = f.read(1024).rstrip()
if file_hash in hashes_in_cloud_storage:
results.append(output_api.PresubmitNotifyResult(
'File already in Cloud Storage, skipping upload: %s' % hash_path))
continue
if not re.match('^([A-Za-z0-9]{40})$', file_hash):
results.append(output_api.PresubmitError(
'Hash file does not contain a valid SHA-1 hash: %s' % hash_path))
continue
if not os.path.exists(file_path):
results.append(output_api.PresubmitError(
'Hash file exists, but file not found: %s' % hash_path))
continue
if cloud_storage.GetHash(file_path) != file_hash:
results.append(output_api.PresubmitError(
'Hash file does not match file\'s actual hash: %s' % hash_path))
continue
try:
cloud_storage.Insert(cloud_storage.DEFAULT_BUCKET, file_hash, file_path)
except cloud_storage.CloudStorageError:
results.append(output_api.PresubmitError(
'Unable to upload to Cloud Storage: %s' % hash_path))
return results
def CheckChangeOnCommit(input_api, output_api):
results = []
results += _SyncFilesToCloud(input_api, output_api)
return results