LEFT | RIGHT |
1 # This Source Code Form is subject to the terms of the Mozilla Public | 1 # This Source Code Form is subject to the terms of the Mozilla Public |
2 # License, v. 2.0. If a copy of the MPL was not distributed with this | 2 # License, v. 2.0. If a copy of the MPL was not distributed with this |
3 # file, You can obtain one at http://mozilla.org/MPL/2.0/. | 3 # file, You can obtain one at http://mozilla.org/MPL/2.0/. |
4 | 4 |
5 import os | 5 import os |
6 import sys | 6 import sys |
7 import re | 7 import re |
8 import subprocess | 8 import subprocess |
9 import shutil | 9 import shutil |
10 import buildtools | 10 import buildtools |
(...skipping 406 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
417 stderr = process.communicate()[1] | 417 stderr = process.communicate()[1] |
418 retcode = process.poll() | 418 retcode = process.poll() |
419 if retcode: | 419 if retcode: |
420 sys.stderr.write(stderr) | 420 sys.stderr.write(stderr) |
421 raise subprocess.CalledProcessError(command, retcode) | 421 raise subprocess.CalledProcessError(command, retcode) |
422 else: | 422 else: |
423 subprocess.check_call(command) | 423 subprocess.check_call(command) |
424 | 424 |
425 | 425 |
426 def runReleaseAutomation(baseDir, scriptName, opts, args, type): | 426 def runReleaseAutomation(baseDir, scriptName, opts, args, type): |
427 keyFiles = [] | 427 keyFile = None |
428 downloadsRepo = os.path.join(baseDir, '..', 'downloads') | 428 downloadsRepo = os.path.join(baseDir, '..', 'downloads') |
429 for option, value in opts: | 429 for option, value in opts: |
430 if option in ('-k', '--key'): | 430 if option in ('-k', '--key'): |
431 keyFiles.append(value) | 431 keyFile = value |
432 elif option in ('-d', '--downloads'): | 432 elif option in ('-d', '--downloads'): |
433 downloadsRepo = value | 433 downloadsRepo = value |
434 | 434 |
435 if len(args) == 0: | 435 if len(args) == 0: |
436 print 'No version number specified for the release' | 436 print 'No version number specified for the release' |
437 usage(scriptName, type, 'release') | 437 usage(scriptName, type, 'release') |
438 return | 438 return |
439 version = args[0] | 439 version = args[0] |
440 if re.search(r'[^\d\.]', version): | 440 if re.search(r'[^\d\.]', version): |
441 print 'Wrong version number format' | 441 print 'Wrong version number format' |
442 usage(scriptName, type, 'release') | 442 usage(scriptName, type, 'release') |
443 return | 443 return |
444 | 444 |
445 if (type == 'chrome' or type == 'safari') and len(keyFiles) != 1: | 445 if type in {'chrome', 'safari'} and keyFile is None: |
446 print >>sys.stderr, 'Error: you must specify a key file for this release
' | 446 print >>sys.stderr, 'Error: you must specify a key file for this release
' |
447 usage(scriptName, type, 'release') | 447 usage(scriptName, type, 'release') |
448 return | 448 return |
449 | 449 |
450 import buildtools.releaseAutomation as releaseAutomation | 450 import buildtools.releaseAutomation as releaseAutomation |
451 releaseAutomation.run(baseDir, type, version, keyFiles, downloadsRepo) | 451 releaseAutomation.run(baseDir, type, version, keyFile, downloadsRepo) |
452 | 452 |
453 | 453 |
454 def updatePSL(baseDir, scriptName, opts, args, type): | 454 def updatePSL(baseDir, scriptName, opts, args, type): |
455 import buildtools.publicSuffixListUpdater as publicSuffixListUpdater | 455 import buildtools.publicSuffixListUpdater as publicSuffixListUpdater |
456 publicSuffixListUpdater.updatePSL(baseDir) | 456 publicSuffixListUpdater.updatePSL(baseDir) |
457 | 457 |
458 with addCommand(lambda baseDir, scriptName, opts, args, type: usage(scriptName,
type), ('help', '-h', '--help')) as command: | 458 with addCommand(lambda baseDir, scriptName, opts, args, type: usage(scriptName,
type), ('help', '-h', '--help')) as command: |
459 command.shortDescription = 'Show this message' | 459 command.shortDescription = 'Show this message' |
460 | 460 |
461 with addCommand(runBuild, 'build') as command: | 461 with addCommand(runBuild, 'build') as command: |
(...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
515 with addCommand(generateDocs, 'docs') as command: | 515 with addCommand(generateDocs, 'docs') as command: |
516 command.shortDescription = 'Generate documentation (requires node.js)' | 516 command.shortDescription = 'Generate documentation (requires node.js)' |
517 command.description = 'Generate documentation files and write them into the
specified directory. This operation requires JsDoc 3 to be installed.' | 517 command.description = 'Generate documentation files and write them into the
specified directory. This operation requires JsDoc 3 to be installed.' |
518 command.addOption('Suppress JsDoc output', short='q', long='quiet') | 518 command.addOption('Suppress JsDoc output', short='q', long='quiet') |
519 command.params = '[options] <directory>' | 519 command.params = '[options] <directory>' |
520 command.supportedTypes = ('gecko', 'chrome') | 520 command.supportedTypes = ('gecko', 'chrome') |
521 | 521 |
522 with addCommand(runReleaseAutomation, 'release') as command: | 522 with addCommand(runReleaseAutomation, 'release') as command: |
523 command.shortDescription = 'Run release automation' | 523 command.shortDescription = 'Run release automation' |
524 command.description = 'Note: If you are not the project owner then you '
"probably don't want to run this!\n\n" 'Runs release automation: crea
tes downloads for the new version, tags ' 'source code repository as well
as downloads and buildtools repository.' | 524 command.description = 'Note: If you are not the project owner then you '
"probably don't want to run this!\n\n" 'Runs release automation: crea
tes downloads for the new version, tags ' 'source code repository as well
as downloads and buildtools repository.' |
525 command.addOption('File containing private key and certificates required to
sign the release. Note that for Chrome releases this option needs to be specifie
d twice: first a key to sign Chrome builds, then another to sign the Safari buil
d.', short='k', long='key', value='file', types=('chrome',)) | 525 command.addOption('File containing private key and certificates required to
sign the release.', short='k', long='key', value='file', types=('chrome', 'safar
i', 'edge')) |
526 command.addOption('Directory containing downloads repository (if omitted ../
downloads is assumed)', short='d', long='downloads', value='dir') | 526 command.addOption('Directory containing downloads repository (if omitted ../
downloads is assumed)', short='d', long='downloads', value='dir') |
527 command.params = '[options] <version>' | 527 command.params = '[options] <version>' |
528 command.supportedTypes = ('gecko', 'chrome', 'safari', 'edge') | 528 command.supportedTypes = ('gecko', 'chrome', 'safari', 'edge') |
529 | 529 |
530 with addCommand(updatePSL, 'updatepsl') as command: | 530 with addCommand(updatePSL, 'updatepsl') as command: |
531 command.shortDescription = 'Updates Public Suffix List' | 531 command.shortDescription = 'Updates Public Suffix List' |
532 command.description = 'Downloads Public Suffix List (see http://publicsuffix
.org/) and generates lib/publicSuffixList.js from it.' | 532 command.description = 'Downloads Public Suffix List (see http://publicsuffix
.org/) and generates lib/publicSuffixList.js from it.' |
533 command.supportedTypes = ('chrome',) | 533 command.supportedTypes = ('chrome',) |
534 | 534 |
535 | 535 |
(...skipping 62 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
598 if option in ('-h', '--help'): | 598 if option in ('-h', '--help'): |
599 usage(scriptName, type, command) | 599 usage(scriptName, type, command) |
600 sys.exit() | 600 sys.exit() |
601 commands[command](baseDir, scriptName, opts, args, type) | 601 commands[command](baseDir, scriptName, opts, args, type) |
602 else: | 602 else: |
603 print 'Command %s is not supported for this application type' % comm
and | 603 print 'Command %s is not supported for this application type' % comm
and |
604 usage(scriptName, type) | 604 usage(scriptName, type) |
605 else: | 605 else: |
606 print 'Command %s is unrecognized' % command | 606 print 'Command %s is unrecognized' % command |
607 usage(scriptName, type) | 607 usage(scriptName, type) |
LEFT | RIGHT |