d9059524e0
flake 3.6.0 introduces a couple of new tests, handle them in the zuul base: * Disable "W504 line break after binary operator", this is a new warning with different coding style. * Fix "F841 local variable 'e' is assigned to but never used" * Fix "W605 invalid escape sequence" - use raw strings for regexes. * Fix "F901 'raise NotImplemented' should be 'raise NotImplementedError'" * Ignore "E252 missing whitespace around parameter equals" since it reports on parameters like: def makeNewJobs(self, old_job, parent: Job=None): Change "flake8: noqa" to "noqa" since "flake8: noqa" is a file level noqa and gets ignored with flake 3.6.0 if it's not at beginning of line - this results in many warnings for files ./zuul/driver/bubblewrap/__init__.py and ./zuul/cmd/migrate.py. Fix any issues there. Change-Id: Ia79bbc8ac0cd8e4819f61bda0091f4398464c5dc
74 lines
2.2 KiB
Python
74 lines
2.2 KiB
Python
# Copyright 2012 Hewlett-Packard Development Company, L.P.
|
|
#
|
|
# 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 logging
|
|
from zuul.source import BaseSource
|
|
from zuul.model import Project
|
|
|
|
|
|
class GitSource(BaseSource):
|
|
name = 'git'
|
|
log = logging.getLogger("zuul.source.Git")
|
|
|
|
def __init__(self, driver, connection, config=None):
|
|
hostname = connection.canonical_hostname
|
|
super(GitSource, self).__init__(driver, connection,
|
|
hostname, config)
|
|
|
|
def getRefSha(self, project, ref):
|
|
raise NotImplementedError()
|
|
|
|
def isMerged(self, change, head=None):
|
|
raise NotImplementedError()
|
|
|
|
def canMerge(self, change, allow_needs):
|
|
raise NotImplementedError()
|
|
|
|
def getChange(self, event, refresh=False):
|
|
return self.connection.getChange(event, refresh)
|
|
|
|
def getChangeByURL(self, url):
|
|
return None
|
|
|
|
def getChangesDependingOn(self, change, projects, tenant):
|
|
return []
|
|
|
|
def getCachedChanges(self):
|
|
return []
|
|
|
|
def getProject(self, name):
|
|
p = self.connection.getProject(name)
|
|
if not p:
|
|
p = Project(name, self)
|
|
self.connection.addProject(p)
|
|
return p
|
|
|
|
def getProjectBranches(self, project, tenant):
|
|
return self.connection.getProjectBranches(project, tenant)
|
|
|
|
def getGitUrl(self, project):
|
|
return self.connection.getGitUrl(project)
|
|
|
|
def getProjectOpenChanges(self, project):
|
|
raise NotImplementedError()
|
|
|
|
def getRequireFilters(self, config):
|
|
return []
|
|
|
|
def getRejectFilters(self, config):
|
|
return []
|
|
|
|
def getRefForChange(self, change):
|
|
raise NotImplementedError()
|