Skip to content

Commit

Permalink
LicenseCheck
Browse files Browse the repository at this point in the history
Change-Id: I185c8956dfe803b1f202c5a005b5e0cc80aadc2e
Signed-off-by: Shenglei Zhang <[email protected]>
  • Loading branch information
shenglei10 committed Jul 13, 2020
1 parent ec9247e commit df0b1e8
Show file tree
Hide file tree
Showing 3 changed files with 128 additions and 0 deletions.
99 changes: 99 additions & 0 deletions .pytool/Plugin/LicenseCheck/LicenseCheck.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,99 @@
import os
import logging
import re
from io import StringIO
from edk2toolext.environment.plugintypes.ci_build_plugin import ICiBuildPlugin
from edk2toolext.environment.var_dict import VarDict
from edk2toollib.utility_functions import RunCmd

class LicenseCheck(ICiBuildPlugin):

"""
A CiBuildPlugin to check the license for new added files.
Configuration options:
"LicenseCheck": {
"IgnoreFiles": []
},
"""

license_format_preflix = 'SPDX-License-Identifier'

bsd2_patent = 'BSD-2-Clause-Patent'

bsd3_patent = 'BSD-3-Clause-Patent'

Readdedfileformat = re.compile(r'\+\+\+ b\/(.*)\n')

file_extension_list = [".c", ".h", ".inf", ".dsc", ".dec", ".py", ".bat", ".sh", ".uni", ".yaml", ".fdf", ".inc", "yml", ".asm", \
".asm16", ".asl", ".vfr", ".s", ".S", ".aslc", ".nasm", ".nasmb", ".idf", ".Vfr", ".H"]

def GetTestName(self, packagename: str, environment: VarDict) -> tuple:
""" Provide the testcase name and classname for use in reporting
testclassname: a descriptive string for the testcase can include whitespace
classname: should be patterned <packagename>.<plugin>.<optionally any unique condition>
Args:
packagename: string containing name of package to build
environment: The VarDict for the test to run in
Returns:
a tuple containing the testcase name and the classname
(testcasename, classname)
"""
return ("Check for license for " + packagename, packagename + ".LicenseCheck")

##
# External function of plugin. This function is used to perform the task of the ci_build_plugin Plugin
#
# - package is the edk2 path to package. This means workspace/packagepath relative.
# - edk2path object configured with workspace and packages path
# - PkgConfig Object (dict) for the pkg
# - EnvConfig Object
# - Plugin Manager Instance
# - Plugin Helper Obj Instance
# - Junit Logger
# - output_stream the StringIO output stream from this plugin via logging
def RunBuildPlugin(self, packagename, Edk2pathObj, pkgconfig, environment, PLM, PLMHelper, tc, output_stream=None):
edk2_path = Edk2pathObj.WorkspacePath

return_buffer = StringIO()
params = "diff --unified=0 origin/master HEAD"
RunCmd("git", params, outstream=return_buffer)
p = return_buffer.getvalue().strip()
patch = p.split("\n")
return_buffer.close()

if "IgnoreFiles" in pkgconfig:
ignore_files = pkgconfig["IgnoreFiles"]

self.ok = True
self.startcheck = False
self.license = True
line_index = 0
for line in lines:
if line.startswith('--- /dev/null'):
nextline = lines[line_index + 1]
added_file = self.Readdedfileformat.search(nextline).group(1)
for f in ignore_files:
if f in added_file:
continue
added_file_extension = os.path.splitext(added_file)[1]
if added_file_extension in self.file_extension_list:
self.startcheck = True
self.license = False
if self.startcheck and self.license_format_preflix in line:
if self.bsd2_patent in line or self.bsd3_patent in line:
self.license = True
if line_index + 1 == count or lines[line_index + 1].startswith('diff --') and self.startcheck:
if not self.license:
error_message = "Invalid License in: " + added_file
logging.error(error_message)
self.startcheck = False
self.license = True
line_index = line_index + 1

if self.license:
return 0
else:
return 1

11 changes: 11 additions & 0 deletions .pytool/Plugin/LicenseCheck/LicenseCheck_plug_in.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
## @file
# CiBuildPlugin used to check char encoding
#
# Copyright (c) Microsoft Corporation.
# SPDX-License-Identifier: BSD-2-Clause-Patent
##
{
"scope": "cibuild",
"name": "Char Encoding Check Test",
"module": "CharEncodingCheck"
}
18 changes: 18 additions & 0 deletions .pytool/Plugin/LicenseCheck/Readme.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
# Character Encoding Check Plugin

This CiBuildPlugin scans all the files in a package to make sure each file is
correctly encoded and all characters can be read. Improper encoding causes
tools to fail in some situations especially in different locals.

## Configuration

The plugin can be configured to ignore certain files.

``` yaml
"CharEncodingCheck": {
"IgnoreFiles": []
}
```
### IgnoreFiles

OPTIONAL List of file to ignore.

0 comments on commit df0b1e8

Please sign in to comment.