forked from stan-dev/docs
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathold_link_check.py
57 lines (48 loc) · 1.44 KB
/
old_link_check.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
import requests
import re
import time
import sys
import pathlib
DOCS_DIR = pathlib.Path(__file__).parent / 'docs'
LINK_FINDER = re.compile(r'(?:version,\s+<a\s+href="(.*)">view\s+current)|(?:link\s+rel="canonical"\s+href="(.*)"\s+/>)')
redirected = set()
with open('redirects.txt', 'r') as f:
for line in f:
if line.startswith("#"):
continue
old, new = line.strip().split()
redirected.add(old)
links = set()
def walk_html():
for version in DOCS_DIR.iterdir():
if version.is_dir():
yield from version.glob('**/*.html')
def find_links():
for html in walk_html():
with open(html, 'r') as f:
for match in LINK_FINDER.finditer(f.read()):
for group in match.groups():
if group:
links.add(group)
def check_links():
broken = 0
for (i, link) in enumerate(links):
raw_link = link.split('#')[0]
if raw_link in redirected:
print(f'Redirected link: {link}')
continue
if i % 50 == 0:
# don't spam the server
time.sleep(2)
response = requests.head(link)
if response.status_code != 200:
broken += 1
print(f'Broken link: {link}')
return broken
if __name__ == '__main__':
find_links()
print(f"Checking {len(links)} links...")
if check_links():
sys.exit(1)
else:
print("Done.")