Merge pull request #14868 from electron/fix-win-dump-syms

chore: fix windows dump syms
This commit is contained in:
Samuel Attard 2018-09-29 13:11:03 +10:00 committed by GitHub
commit 531a4c5b8c
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
6 changed files with 52 additions and 23 deletions

View file

@ -179,6 +179,21 @@ step-nodejs-headers-build: &step-nodejs-headers-build
cd src cd src
ninja -C out/Default third_party/electron_node:headers ninja -C out/Default third_party/electron_node:headers
step-electron-publish: &step-electron-publish
run:
name: Publish Electron Dist
command: |
cd src/electron
if [ "$ELECTRON_RELEASE" == "1" ]; then
if [ "$UPLOAD_TO_S3" != "1" ]; then
echo 'Uploading Electron release distribution to github releases'
script/upload.py
else
echo 'Uploading Electron release distribution to s3'
script/upload.py --upload_to_s3
fi
fi
step-persist-data-for-tests: &step-persist-data-for-tests step-persist-data-for-tests: &step-persist-data-for-tests
persist_to_workspace: persist_to_workspace:
root: . root: .
@ -411,6 +426,9 @@ steps-electron-build-for-publish: &steps-electron-build-for-publish
# Node.js headers # Node.js headers
- *step-nodejs-headers-build - *step-nodejs-headers-build
# Publish
- *step-electron-publish
steps-native-mksnapshot-build: &steps-native-mksnapshot-build steps-native-mksnapshot-build: &steps-native-mksnapshot-build
steps: steps:

View file

@ -31,6 +31,7 @@ build_script:
- ninja -C out/Default electron:electron_dist_zip - ninja -C out/Default electron:electron_dist_zip
- ninja -C out/Default electron:electron_mksnapshot_zip - ninja -C out/Default electron:electron_mksnapshot_zip
- ninja -C out/Default electron:electron_chromedriver_zip - ninja -C out/Default electron:electron_chromedriver_zip
- ninja -C out/Default third_party/electron_node:headers
- appveyor PushArtifact out/Default/dist.zip - appveyor PushArtifact out/Default/dist.zip
- appveyor PushArtifact out/Default/chromedriver.zip - appveyor PushArtifact out/Default/chromedriver.zip
@ -38,15 +39,17 @@ build_script:
- ps: >- - ps: >-
if ($env:GN_CONFIG -eq 'release') { if ($env:GN_CONFIG -eq 'release') {
ninja -C out/Default third_party/breakpad:dump_syms ninja -C out/Default third_party/breakpad:dump_syms
python electron\script\dump-symbols.py -d %cd%/out/Default/electron.breakpad.syms }
- if "%GN_CONFIG%"=="release" ( python electron\script\dump-symbols.py -d %cd%\out\Default\electron.breakpad.syms -v)
- ps: >-
if ($env:GN_CONFIG -eq 'release') {
python electron\script\zip-symbols.py python electron\script\zip-symbols.py
appveyor PushArtifact out/Default/electron.breakpad.syms appveyor PushArtifact out/Default/symbols.zip
} }
test_script: 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 ) - 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: >- - ps: >-
if ($env:GN_CONFIG -eq 'testing') { if ($env:GN_CONFIG -eq 'testing') {
ninja -C out/Default third_party/electron_node:headers
New-Item .\out\Default\gen\node_headers\Release -Type directory New-Item .\out\Default\gen\node_headers\Release -Type directory
Copy-Item -path .\out\Default\electron.lib -destination .\out\Default\gen\node_headers\Release\node.lib Copy-Item -path .\out\Default\electron.lib -destination .\out\Default\gen\node_headers\Release\node.lib
} else { } else {

View file

@ -5,7 +5,8 @@ import os
import sys import sys
from lib.config import PLATFORM, enable_verbose_mode, is_verbose_mode from lib.config import PLATFORM, enable_verbose_mode, is_verbose_mode
from lib.util import get_electron_branding, execute, rm_rf, get_out_dir from lib.util import get_electron_branding, execute, rm_rf, get_out_dir, \
GN_SRC_DIR
ELECTRON_ROOT = os.path.abspath(os.path.dirname(os.path.dirname(__file__))) ELECTRON_ROOT = os.path.abspath(os.path.dirname(os.path.dirname(__file__)))
SOURCE_ROOT = os.path.abspath(os.path.dirname(ELECTRON_ROOT)) SOURCE_ROOT = os.path.abspath(os.path.dirname(ELECTRON_ROOT))
@ -46,7 +47,15 @@ def main():
'--jobs=16', '--jobs=16',
os.path.relpath(build_path), os.path.relpath(build_path),
] ]
execute([sys.executable, generate_breakpad_symbols] + args) if is_verbose_mode():
args += ['-v']
#Make sure msdia140.dll is in the path (needed for dump_syms.exe)
env = os.environ.copy()
msdia140_dll_path = os.path.join(GN_SRC_DIR, 'third_party', 'llvm-build',
'Release+Asserts', 'bin')
env['PATH'] = os.path.pathsep.join(
[env.get('PATH', '')] + [msdia140_dll_path])
execute([sys.executable, generate_breakpad_symbols] + args, env)
def get_names_from_branding(): def get_names_from_branding():
variables = get_electron_branding() variables = get_electron_branding()

View file

@ -10,16 +10,13 @@ from lib.util import get_electron_branding, execute, rm_rf, safe_mkdir, s3put, \
SOURCE_ROOT = os.path.abspath(os.path.dirname(os.path.dirname(__file__))) SOURCE_ROOT = os.path.abspath(os.path.dirname(os.path.dirname(__file__)))
RELEASE_DIR = get_out_dir() RELEASE_DIR = get_out_dir()
GEN_DIR = os.path.join(RELEASE_DIR, 'gen')
PROJECT_NAME = get_electron_branding()['project_name'] PROJECT_NAME = get_electron_branding()['project_name']
PRODUCT_NAME = get_electron_branding()['product_name'] PRODUCT_NAME = get_electron_branding()['product_name']
SYMBOLS_DIR = os.path.join(
if PLATFORM == 'win32': RELEASE_DIR, '{0}.breakpad.syms'.format(PROJECT_NAME)
SYMBOLS_DIR = os.path.join(GEN_DIR, 'symbols') )
else:
SYMBOLS_DIR = os.path.join(GEN_DIR, '{0}.breakpad.syms'.format(PROJECT_NAME))
PDB_LIST = [ PDB_LIST = [
os.path.join(RELEASE_DIR, '{0}.exe.pdb'.format(PROJECT_NAME)) os.path.join(RELEASE_DIR, '{0}.exe.pdb'.format(PROJECT_NAME))

View file

@ -65,7 +65,7 @@ def main():
upload_electron(release, electron_zip, args) upload_electron(release, electron_zip, args)
if get_target_arch() != 'mips64el': if get_target_arch() != 'mips64el':
symbols_zip = os.path.join(OUT_DIR, SYMBOLS_NAME) symbols_zip = os.path.join(OUT_DIR, SYMBOLS_NAME)
shutil.copy2(os.path.join(OUT_DIR, 'symobls.zip'), symbols_zip) shutil.copy2(os.path.join(OUT_DIR, 'symbols.zip'), symbols_zip)
upload_electron(release, symbols_zip, args) upload_electron(release, symbols_zip, args)
if PLATFORM == 'darwin': if PLATFORM == 'darwin':
api_path = os.path.join(OUT_DIR, 'electron-api.json') api_path = os.path.join(OUT_DIR, 'electron-api.json')
@ -77,12 +77,15 @@ def main():
shutil.copy2(os.path.join(OUT_DIR, 'dsym.zip'), dsym_zip) shutil.copy2(os.path.join(OUT_DIR, 'dsym.zip'), dsym_zip)
upload_electron(release, dsym_zip, args) upload_electron(release, dsym_zip, args)
elif PLATFORM == 'win32': elif PLATFORM == 'win32':
upload_electron(release, os.path.join(OUT_DIR, PDB_NAME), args) pdb_zip = os.path.join(OUT_DIR, PDB_NAME)
shutil.copy2(os.path.join(OUT_DIR, 'pdb.zip'), pdb_zip)
upload_electron(release, pdb_zip, args)
# Upload free version of ffmpeg. # Upload free version of ffmpeg.
ffmpeg = get_zip_name('ffmpeg', ELECTRON_VERSION) ffmpeg = get_zip_name('ffmpeg', ELECTRON_VERSION)
ffmpeg_zip = os.path.join(OUT_DIR, ffmpeg) ffmpeg_zip = os.path.join(OUT_DIR, ffmpeg)
shutil.copy2(os.path.join(OUT_DIR, 'ffmpeg.zip'), ffmpeg_zip) ffmpeg_build_path = os.path.join(GN_SRC_DIR, 'out', 'ffmpeg', 'ffmpeg.zip')
shutil.copy2(ffmpeg_build_path, ffmpeg_zip)
upload_electron(release, ffmpeg_zip, args) upload_electron(release, ffmpeg_zip, args)
chromedriver = get_zip_name('chromedriver', ELECTRON_VERSION) chromedriver = get_zip_name('chromedriver', ELECTRON_VERSION)

View file

@ -56,7 +56,6 @@ jobs:
cd src cd src
ninja -C out/Default third_party/electron_node:headers ninja -C out/Default third_party/electron_node:headers
displayName: Build Node.js headers for testing displayName: Build Node.js headers for testing
condition: and(succeeded(), eq(variables['RUN_TESTS'], '1'))
- bash: | - bash: |
cd src cd src