refactor: do not use electron.gyp contents in the verify-ffmpeg script
Also run verify ffmpeg with cmd instead of powershell
This commit is contained in:
parent
8e525f965d
commit
57a4d86669
4 changed files with 39 additions and 29 deletions
|
@ -107,7 +107,7 @@ gn-build-steps: &gn-build-steps
|
|||
name: Verify ffmpeg
|
||||
command: |
|
||||
if [ "$RUN_TESTS" != "false" ] && [ "$BUILD_FFMPEG" == "true" ]; then
|
||||
python src/electron/script/verify-ffmpeg.py -c Default --source-root "$PWD/src" --ffmpeg-path "$PWD/src/out/ffmpeg"
|
||||
python src/electron/script/verify-ffmpeg.py --build-dir out/Default --source-root "$PWD/src" --ffmpeg-path out/ffmpeg
|
||||
fi
|
||||
- run:
|
||||
name: Test
|
||||
|
|
|
@ -29,9 +29,9 @@ build_script:
|
|||
- ninja -C out/ffmpeg third_party/ffmpeg
|
||||
- ninja -C out/Default electron:electron_dist_zip
|
||||
test_script:
|
||||
- if "%GN_CONFIG%"=="testing" ( echo Verifying non proprietary ffmpeg & python electron\script\verify-ffmpeg.py --build-dir out\Default --source-root %cd% --ffmpeg-path out\ffmpeg )
|
||||
- ps: >-
|
||||
if ($env:GN_CONFIG -eq 'testing') {
|
||||
python electron\script\verify-ffmpeg.py -c Default --source-root "$PWD" --ffmpeg-path "$PWD\out\ffmpeg"
|
||||
ninja -C out/Default third_party/electron_node:headers
|
||||
$env:npm_config_nodedir="$pwd/out/Default/gen/node_headers"
|
||||
$env:npm_config_msvs_version="2017"
|
||||
|
@ -43,7 +43,7 @@ test_script:
|
|||
} else {
|
||||
echo "Skipping tests for $env:GN_CONFIG build"
|
||||
}
|
||||
- if "%GN_CONFIG%"=="testing" ( echo "Running test suite" & .\out\Default\electron.exe electron\spec --ci )
|
||||
- if "%GN_CONFIG%"=="testing" ( echo Running test suite & .\out\Default\electron.exe electron\spec --ci )
|
||||
artifacts:
|
||||
- path: src/out/Default/dist.zip
|
||||
name: dist.zip
|
||||
|
|
|
@ -1,6 +1,7 @@
|
|||
#!/usr/bin/env python
|
||||
|
||||
import subprocess
|
||||
import sys
|
||||
|
||||
from util import scoped_cwd
|
||||
|
||||
|
@ -9,9 +10,15 @@ class GNProject:
|
|||
def __init__(self, out_dir):
|
||||
self.out_dir = out_dir
|
||||
|
||||
def _get_executable_name(self):
|
||||
if sys.platform == 'win32':
|
||||
return 'gn.bat'
|
||||
|
||||
return 'gn'
|
||||
|
||||
def run(self, command_name, command_args):
|
||||
with scoped_cwd(self.out_dir):
|
||||
complete_args = ['gn', command_name, '.'] + command_args
|
||||
complete_args = [self._get_executable_name(), command_name, '.'] + command_args
|
||||
return subprocess.check_output(complete_args)
|
||||
|
||||
def args(self):
|
||||
|
|
|
@ -5,40 +5,42 @@ import shutil
|
|||
import subprocess
|
||||
import sys
|
||||
|
||||
from lib.util import electron_gyp, rm_rf
|
||||
from lib.gn import gn
|
||||
from lib.util import rm_rf
|
||||
|
||||
|
||||
SOURCE_ROOT = os.path.abspath(os.path.dirname(os.path.dirname(__file__)))
|
||||
FFMPEG_LIBCC_PATH = os.path.join(SOURCE_ROOT, 'vendor', 'download',
|
||||
'libchromiumcontent', 'ffmpeg')
|
||||
|
||||
PROJECT_NAME = electron_gyp()['project_name%']
|
||||
PRODUCT_NAME = electron_gyp()['product_name%']
|
||||
|
||||
|
||||
def main():
|
||||
args = parse_args()
|
||||
os.chdir(args.source_root)
|
||||
|
||||
app_path = create_app_copy(args)
|
||||
initial_app_path = os.path.join(os.path.abspath(args.source_root), args.build_dir)
|
||||
app_path = create_app_copy(initial_app_path)
|
||||
|
||||
# Those are the same in the original app and its copy.
|
||||
# So it is ok to retrieve them from the original build dir and use in the copy.
|
||||
product_name = gn(initial_app_path).args().get_string('electron_product_name')
|
||||
project_name = gn(initial_app_path).args().get_string('electron_project_name')
|
||||
|
||||
if sys.platform == 'darwin':
|
||||
electron = os.path.join(app_path, 'Contents', 'MacOS', PRODUCT_NAME)
|
||||
electron = os.path.join(app_path, 'Contents', 'MacOS', product_name)
|
||||
ffmpeg_name = 'libffmpeg.dylib'
|
||||
ffmpeg_app_path = os.path.join(app_path, 'Contents', 'Frameworks',
|
||||
'{0} Framework.framework'.format(PROJECT_NAME),
|
||||
'{0} Framework.framework'.format(product_name),
|
||||
'Libraries')
|
||||
elif sys.platform == 'win32':
|
||||
electron = os.path.join(app_path, '{0}.exe'.format(PROJECT_NAME))
|
||||
electron = os.path.join(app_path, '{0}.exe'.format(project_name))
|
||||
ffmpeg_app_path = app_path
|
||||
ffmpeg_name = 'ffmpeg.dll'
|
||||
else:
|
||||
electron = os.path.join(app_path, PROJECT_NAME)
|
||||
electron = os.path.join(app_path, project_name)
|
||||
ffmpeg_app_path = app_path
|
||||
ffmpeg_name = 'libffmpeg.so'
|
||||
|
||||
# Copy ffmpeg without proprietary codecs into app
|
||||
shutil.copy(os.path.join(args.ffmpeg_path, ffmpeg_name), ffmpeg_app_path)
|
||||
# Copy ffmpeg without proprietary codecs into app.
|
||||
ffmpeg_lib_path = os.path.join(os.path.abspath(args.source_root), args.ffmpeg_path, ffmpeg_name)
|
||||
shutil.copy(ffmpeg_lib_path, ffmpeg_app_path)
|
||||
|
||||
returncode = 0
|
||||
try:
|
||||
|
@ -56,13 +58,13 @@ def main():
|
|||
|
||||
|
||||
# Create copy of app to install ffmpeg library without proprietary codecs into
|
||||
def create_app_copy(args):
|
||||
initial_app_path = os.path.join(args.source_root, 'out', args.config)
|
||||
app_path = os.path.join(args.source_root, 'out',
|
||||
args.config + '-no-proprietary-codecs')
|
||||
def create_app_copy(initial_app_path):
|
||||
app_path = os.path.join(os.path.dirname(initial_app_path),
|
||||
os.path.basename(initial_app_path) + '-no-proprietary-codecs')
|
||||
|
||||
if sys.platform == 'darwin':
|
||||
app_name = '{0}.app'.format(PRODUCT_NAME)
|
||||
product_name = gn(initial_app_path).args().get_string('electron_product_name')
|
||||
app_name = '{0}.app'.format(product_name)
|
||||
initial_app_path = os.path.join(initial_app_path, app_name)
|
||||
app_path = os.path.join(app_path, app_name)
|
||||
|
||||
|
@ -72,16 +74,17 @@ def create_app_copy(args):
|
|||
|
||||
def parse_args():
|
||||
parser = argparse.ArgumentParser(description='Test non-proprietary ffmpeg')
|
||||
parser.add_argument('-c', '--config',
|
||||
help='Test with Release or Debug configuration',
|
||||
default='D',
|
||||
required=False)
|
||||
parser.add_argument('-b', '--build-dir',
|
||||
help='Path to an Electron build folder. Relative to the --source-root.',
|
||||
default=None,
|
||||
required=True)
|
||||
parser.add_argument('--source-root',
|
||||
default=SOURCE_ROOT,
|
||||
required=False)
|
||||
parser.add_argument('--ffmpeg-path',
|
||||
default=FFMPEG_LIBCC_PATH,
|
||||
required=False)
|
||||
help='Path to a folder with a ffmpeg lib. Relative to the --source-root.',
|
||||
default=None,
|
||||
required=True)
|
||||
return parser.parse_args()
|
||||
|
||||
if __name__ == '__main__':
|
||||
|
|
Loading…
Reference in a new issue