Add chromedriver to build

Make sure certain paths/files don't make it into the dist zip
Don't build the content shell test_runner
Make sure libffmpeg.dylib gets put in the right place
Run verify-ffmpeg on Mac builds
Add ffmpeg build to VSTS
This commit is contained in:
John Kleinschmidt 2018-09-18 09:48:01 -04:00
parent 5317c2754f
commit e78d84165a
4 changed files with 36 additions and 9 deletions

View file

@ -222,6 +222,7 @@ static_library("electron_lib") {
"//base", "//base",
"//base:i18n", "//base:i18n",
"//chrome/common:constants", "//chrome/common:constants",
"//chrome/test/chromedriver",
"//components/network_session_configurator/common", "//components/network_session_configurator/common",
"//components/prefs", "//components/prefs",
"//components/printing/common", "//components/printing/common",
@ -497,14 +498,10 @@ if (is_mac) {
] ]
} }
if (!is_component_build) { if (is_component_ffmpeg) {
bundle_data("electron_framework_libraries") { bundle_data("electron_framework_libraries") {
sources = [] sources = [ "$root_out_dir/libffmpeg.dylib" ]
public_deps = [] public_deps = [ "//third_party/ffmpeg:ffmpeg" ]
if (is_component_ffmpeg) {
sources += [ "$root_out_dir/libffmpeg.dylib" ]
public_deps += [ "//third_party/ffmpeg:ffmpeg" ]
}
outputs = [ outputs = [
"{{bundle_contents_dir}}/Libraries/{{source_file_part}}", "{{bundle_contents_dir}}/Libraries/{{source_file_part}}",
] ]
@ -531,7 +528,7 @@ if (is_mac) {
mac_framework_bundle("electron_framework") { mac_framework_bundle("electron_framework") {
output_name = electron_framework_name output_name = electron_framework_name
framework_version = electron_framework_version framework_version = electron_framework_version
framework_contents = [ "Resources" ] framework_contents = [ "Resources", "Libraries" ]
public_deps = [ public_deps = [
":electron_lib", ":electron_lib",
] ]

View file

@ -7,7 +7,7 @@ static_library("brightray") {
"//components/network_session_configurator/common", "//components/network_session_configurator/common",
"//components/prefs", "//components/prefs",
"//content/public/browser", "//content/public/browser",
"//content/shell:resources", "//content/shell:copy_shell_resources",
"//net:extras", "//net:extras",
"//net:net_with_v8", "//net:net_with_v8",
"//skia", "//skia",

View file

@ -10,6 +10,27 @@ LINUX_BINARIES_TO_STRIP = [
'libnode.so' 'libnode.so'
] ]
EXTENSIONS_TO_SKIP = [
'.pdb'
]
PATHS_TO_SKIP = [
'angledata',
'swiftshader',
'resources/inspector'
]
def skip_path(dep):
should_skip = False
for path in PATHS_TO_SKIP:
if dep.startswith(path):
print 'Skipping: '+dep
should_skip = True
for extension in EXTENSIONS_TO_SKIP:
if dep.endswith(extension):
print 'Skipping: '+dep
should_skip = True
def strip_binaries(target_cpu, dep): def strip_binaries(target_cpu, dep):
for binary in LINUX_BINARIES_TO_STRIP: for binary in LINUX_BINARIES_TO_STRIP:
if dep.endswith(binary): if dep.endswith(binary):
@ -48,6 +69,8 @@ def main(argv):
for dep in dist_files: for dep in dist_files:
if target_os == 'linux': if target_os == 'linux':
strip_binaries(target_cpu, dep) strip_binaries(target_cpu, dep)
if skip_path(dep):
continue
if os.path.isdir(dep): if os.path.isdir(dep):
for root, dirs, files in os.walk(dep): for root, dirs, files in os.walk(dep):
for file in files: for file in files:

View file

@ -51,6 +51,13 @@ jobs:
ninja -C out/Default electron:electron_app ninja -C out/Default electron:electron_app
displayName: Ninja build app displayName: Ninja build app
- bash: |
cd src
gn gen out/ffmpeg --args='import("//electron/build/args/ffmpeg.gn") cc_wrapper="'"$SCCACHE_PATH"'"'" $GN_EXTRA_ARGS"
ninja -C out/ffmpeg third_party/ffmpeg
displayName: Non proprietary ffmpeg build
condition: and(succeeded(), eq(variables['RUN_TESTS'], '1'))
- bash: | - bash: |
"$SCCACHE_BINARY" --stop-server "$SCCACHE_BINARY" --stop-server
displayName: Check sccache stats after build displayName: Check sccache stats after build