mirror of
				https://github.com/ytdl-org/youtube-dl.git
				synced 2025-10-29 09:26:20 -07:00 
			
		
		
		
	re-worked release workflow, it is one-step and creates GPG signatures now
This commit is contained in:
		
							
								
								
									
										17
									
								
								.tarignore
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								.tarignore
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,17 @@ | |||||||
|  | updates_key.pem | ||||||
|  | *.pyc | ||||||
|  | *.pyo | ||||||
|  | youtube-dl.exe | ||||||
|  | wine-py2exe/ | ||||||
|  | py2exe.log | ||||||
|  | *.kate-swp | ||||||
|  | build/ | ||||||
|  | dist/ | ||||||
|  | MANIFEST | ||||||
|  | *.DS_Store | ||||||
|  | youtube-dl.tar.gz | ||||||
|  | .coverage | ||||||
|  | cover/ | ||||||
|  | __pycache__/ | ||||||
|  | .git/ | ||||||
|  | *~ | ||||||
							
								
								
									
										8
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										8
									
								
								Makefile
									
									
									
									
									
								
							| @@ -1,7 +1,7 @@ | |||||||
| all: youtube-dl README.md README.txt youtube-dl.1 youtube-dl.bash-completion | all: youtube-dl README.md README.txt youtube-dl.1 youtube-dl.bash-completion | ||||||
|  |  | ||||||
| clean: | clean: | ||||||
| 	rm -rf youtube-dl youtube-dl.exe youtube-dl.1 youtube-dl.bash-completion README.txt MANIFEST build/ dist/ | 	rm -rf youtube-dl youtube-dl.exe youtube-dl.1 youtube-dl.bash-completion README.txt MANIFEST build/ dist/ .coverage cover/ | ||||||
|  |  | ||||||
| PREFIX=/usr/local | PREFIX=/usr/local | ||||||
| BINDIR=$(PREFIX)/bin | BINDIR=$(PREFIX)/bin | ||||||
| @@ -43,7 +43,5 @@ youtube-dl.bash-completion: youtube_dl/*.py devscripts/bash-completion.in | |||||||
| 	python devscripts/bash-completion.py | 	python devscripts/bash-completion.py | ||||||
|  |  | ||||||
| youtube-dl.tar.gz: all | youtube-dl.tar.gz: all | ||||||
| 	tar -czf youtube-dl.tar.gz -s "|^./|./youtube-dl/|" --exclude="updates_key.pem" \ | 	tar -cvzf youtube-dl.tar.gz -s "|^./|./youtube-dl/|" \ | ||||||
| 		--exclude="*.pyc" --exclude="*.pyo" --exclude="*~" --exclude="youtube-dl.exe" \ | 		--exclude-from=".tarignore" -- . | ||||||
| 		--exclude="wine-py2exe/" --exclude="py2exe.log" --exclude="*.kate-swp" \ |  | ||||||
| 		--exclude="build/" --exclude="dist/" --exclude="MANIFEST" --exclude=".git/" . |  | ||||||
|   | |||||||
							
								
								
									
										0
									
								
								devscripts/bash-completion.py
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								devscripts/bash-completion.py
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
								
								
									
										33
									
								
								devscripts/gh-pages/add-version.py
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										33
									
								
								devscripts/gh-pages/add-version.py
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,33 @@ | |||||||
|  | #!/usr/bin/env python3 | ||||||
|  |  | ||||||
|  | import json | ||||||
|  | import sys | ||||||
|  | import hashlib | ||||||
|  | import urllib.request | ||||||
|  |  | ||||||
|  | if len(sys.argv) <= 1: | ||||||
|  | 	print('Specify the version number as parameter') | ||||||
|  | 	sys.exit() | ||||||
|  | version = sys.argv[1] | ||||||
|  |  | ||||||
|  | with open('update/LATEST_VERSION', 'w') as f: | ||||||
|  | 	f.write(version) | ||||||
|  |  | ||||||
|  | versions_info = json.load(open('update/versions.json')) | ||||||
|  | if 'signature' in versions_info: | ||||||
|  | 	del versions_info['signature'] | ||||||
|  |  | ||||||
|  | new_version = {} | ||||||
|  |  | ||||||
|  | filenames = {'bin': 'youtube-dl', 'exe': 'youtube-dl.exe', 'tar': 'youtube-dl-%s.tar.gz' % version} | ||||||
|  | for key, filename in filenames.items(): | ||||||
|  | 	print('Downloading and checksumming %s...' %filename) | ||||||
|  | 	url = 'http://youtube-dl.org/downloads/%s/%s' % (version, filename) | ||||||
|  | 	data = urllib.request.urlopen(url).read() | ||||||
|  | 	sha256sum = hashlib.sha256(data).hexdigest() | ||||||
|  | 	new_version[key] = (url, sha256sum) | ||||||
|  |  | ||||||
|  | versions_info['versions'][version] = new_version | ||||||
|  | versions_info['latest'] = version | ||||||
|  |  | ||||||
|  | json.dump(versions_info, open('update/versions.json', 'w'), indent=4, sort_keys=True) | ||||||
| @@ -4,18 +4,13 @@ import shutil | |||||||
| import subprocess | import subprocess | ||||||
| import tempfile | import tempfile | ||||||
| import urllib.request | import urllib.request | ||||||
|  | import json | ||||||
|  |  | ||||||
| URL = 'https://github.com/downloads/rg3/youtube-dl/youtube-dl' | versions_info = json.load(open('update/versions.json')) | ||||||
|  | version = versions_info['latest'] | ||||||
|  | URL = versions_info['versions'][version]['bin'][0] | ||||||
|  |  | ||||||
| with tempfile.NamedTemporaryFile(suffix='youtube-dl', delete=True) as ytdl_file: | data = urllib.request.urlopen(URL).read() | ||||||
|     with urllib.request.urlopen(URL) as dl: |  | ||||||
|         shutil.copyfileobj(dl, ytdl_file) |  | ||||||
|  |  | ||||||
|     ytdl_file.seek(0) |  | ||||||
|     data = ytdl_file.read() |  | ||||||
|  |  | ||||||
|     ytdl_file.flush() |  | ||||||
|     version = subprocess.check_output(['python3', ytdl_file.name, '--version']).decode('ascii').strip() |  | ||||||
|  |  | ||||||
| # Read template page | # Read template page | ||||||
| with open('download.html.in', 'r', encoding='utf-8') as tmplf: | with open('download.html.in', 'r', encoding='utf-8') as tmplf: | ||||||
| @@ -29,5 +24,9 @@ template = template.replace('@PROGRAM_URL@', URL) | |||||||
| template = template.replace('@PROGRAM_MD5SUM@', md5sum) | template = template.replace('@PROGRAM_MD5SUM@', md5sum) | ||||||
| template = template.replace('@PROGRAM_SHA1SUM@', sha1sum) | template = template.replace('@PROGRAM_SHA1SUM@', sha1sum) | ||||||
| template = template.replace('@PROGRAM_SHA256SUM@', sha256sum) | template = template.replace('@PROGRAM_SHA256SUM@', sha256sum) | ||||||
|  | template = template.replace('@EXE_URL@', versions_info['versions'][version]['exe'][0]) | ||||||
|  | template = template.replace('@EXE_SHA256SUM@', versions_info['versions'][version]['exe'][1]) | ||||||
|  | template = template.replace('@TAR_URL@', versions_info['versions'][version]['tar'][0]) | ||||||
|  | template = template.replace('@TAR_SHA256SUM@', versions_info['versions'][version]['tar'][1]) | ||||||
| with open('download.html', 'w', encoding='utf-8') as dlf: | with open('download.html', 'w', encoding='utf-8') as dlf: | ||||||
|     dlf.write(template) |     dlf.write(template) | ||||||
|   | |||||||
| @@ -1,15 +1,13 @@ | |||||||
| #! /usr/bin/env python3 | #!/usr/bin/env python3 | ||||||
| 
 | 
 | ||||||
| import rsa | import rsa | ||||||
| import json | import json | ||||||
| from binascii import hexlify | from binascii import hexlify | ||||||
| 
 | 
 | ||||||
| # TODO path discovery |  | ||||||
| versions_info = json.load(open('update/versions.json')) | versions_info = json.load(open('update/versions.json')) | ||||||
| if 'signature' in versions_info: | if 'signature' in versions_info: | ||||||
| 	del versions_info['signature'] | 	del versions_info['signature'] | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| print('Enter the PKCS1 private key, followed by a blank line:') | print('Enter the PKCS1 private key, followed by a blank line:') | ||||||
| privkey = '' | privkey = '' | ||||||
| while True: | while True: | ||||||
							
								
								
									
										0
									
								
								devscripts/make_readme.py
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								devscripts/make_readme.py
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							| @@ -1,11 +1,74 @@ | |||||||
| #!/bin/sh | #!/bin/sh | ||||||
|  |  | ||||||
|  | # IMPORTANT: the following assumptions are made | ||||||
|  | # * you did --set-upstream | ||||||
|  | # * the gh-pages branch is named so locally | ||||||
|  | # * the git config user.signingkey is properly set | ||||||
|  |  | ||||||
|  | # You will need | ||||||
|  | # pip install coverage nose rsa | ||||||
|  |  | ||||||
|  | set -e | ||||||
|  |  | ||||||
| if [ -z "$1" ]; then echo "ERROR: specify version number like this: $0 1994.09.06"; exit 1; fi | if [ -z "$1" ]; then echo "ERROR: specify version number like this: $0 1994.09.06"; exit 1; fi | ||||||
| version="$1" | version="$1" | ||||||
| if [ ! -z "`git tag | grep "$version"`" ]; then echo 'ERROR: version already present'; exit 1; fi | if [ ! -z "`git tag | grep "$version"`" ]; then echo 'ERROR: version already present'; exit 1; fi | ||||||
| if [ ! -z "`git status --porcelain`" ]; then echo 'ERROR: the working directory is not clean; commit or stash changes'; exit 1; fi | if [ ! -z "`git status --porcelain | grep -v CHANGELOG`" ]; then echo 'ERROR: the working directory is not clean; commit or stash changes'; exit 1; fi | ||||||
| sed -i "s/__version__ = '.*'/__version__ = '$version'/" youtube_dl/__init__.py | if [ ! -f "updates_key.pem" ]; then echo 'ERROR: updates_key.pem missing'; exit 1; fi | ||||||
| make all |  | ||||||
| git add -A | echo "\n### First of all, testing..." | ||||||
|  | make clean | ||||||
|  | nosetests --with-coverage --cover-package=youtube_dl --cover-html test || exit 1 | ||||||
|  |  | ||||||
|  | echo "\n### Changing version in version.py..." | ||||||
|  | sed -i~ "s/__version__ = '.*'/__version__ = '$version'/" youtube_dl/version.py | ||||||
|  |  | ||||||
|  | echo "\n### Committing CHANGELOG README.md and youtube_dl/version.py..." | ||||||
|  | make README.md | ||||||
|  | git add CHANGELOG README.md youtube_dl/version.py | ||||||
| git commit -m "release $version" | git commit -m "release $version" | ||||||
| git tag -m "Release $version" "$version" |  | ||||||
|  | echo "\n### Now tagging, signing and pushing..." | ||||||
|  | git tag -s -m "Release $version" "$version" | ||||||
|  | git show "$version" | ||||||
|  | read -p "Is it good, can I push? (y/n) " -n 1 | ||||||
|  | if [[ ! $REPLY =~ ^[Yy]$ ]]; then exit 1; fi | ||||||
|  | echo | ||||||
|  | git push | ||||||
|  |  | ||||||
|  | echo "\n### OK, now it is time to build the binaries..." | ||||||
|  | REV=$(git rev-parse HEAD) | ||||||
|  | make youtube-dl youtube-dl.tar.gz | ||||||
|  | wget "http://jeromelaheurte.net:8142/download/rg3/youtube-dl/youtube-dl.exe?rev=$REV" -O youtube-dl.exe || \ | ||||||
|  | 	wget "http://jeromelaheurte.net:8142/build/rg3/youtube-dl/youtube-dl.exe?rev=$REV" -O youtube-dl.exe | ||||||
|  | mkdir -p "update_staging/$version" | ||||||
|  | mv youtube-dl youtube-dl.exe "update_staging/$version" | ||||||
|  | mv youtube-dl.tar.gz "update_staging/$version/youtube-dl-$version.tar.gz" | ||||||
|  | git checkout HEAD -- youtube-dl youtube-dl.exe | ||||||
|  |  | ||||||
|  | echo "\n### Signing and uploading the new binaries to youtube-dl.org..." | ||||||
|  | for f in update_staging/$version/*; do gpg --detach-sig "$f"; done | ||||||
|  | scp -r "update_staging/$version" ytdl@youtube-dl.org:html/downloads/ | ||||||
|  | rm -r update_staging | ||||||
|  |  | ||||||
|  | echo "\n### Now switching to gh-pages..." | ||||||
|  | MASTER=$(git rev-parse --abbrev-ref HEAD) | ||||||
|  | git checkout gh-pages | ||||||
|  | git checkout "$MASTER" -- devscripts/gh-pages/ | ||||||
|  | git reset devscripts/gh-pages/ | ||||||
|  | devscripts/gh-pages/add-version.py $version | ||||||
|  | devscripts/gh-pages/sign-versions.py < updates_key.pem | ||||||
|  | devscripts/gh-pages/generate-download.py | ||||||
|  | devscripts/gh-pages/update-copyright.py | ||||||
|  | rm -r test_coverage | ||||||
|  | mv cover test_coverage | ||||||
|  | git add *.html *.html.in update test_coverage | ||||||
|  | git commit -m "release $version" | ||||||
|  | git show HEAD | ||||||
|  | read -p "Is it good, can I push? (y/n) " -n 1 | ||||||
|  | if [[ ! $REPLY =~ ^[Yy]$ ]]; then exit 1; fi | ||||||
|  | echo | ||||||
|  | git push | ||||||
|  |  | ||||||
|  | echo "\n### DONE!" | ||||||
|  | git checkout $MASTER | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user