2022-02-19 21:05:56 -06:00
|
|
|
"""Test the Theme class."""
|
2009-02-15 09:10:10 -06:00
|
|
|
|
|
|
|
import os
|
|
|
|
|
2018-06-19 07:58:06 -05:00
|
|
|
import alabaster
|
2020-03-14 13:46:37 -05:00
|
|
|
import pytest
|
2020-11-11 05:00:27 -06:00
|
|
|
|
2023-08-07 15:02:25 -05:00
|
|
|
import sphinx.builders.html
|
2017-04-20 06:19:55 -05:00
|
|
|
from sphinx.theming import ThemeError
|
2015-03-14 10:47:43 -05:00
|
|
|
|
|
|
|
|
2017-01-05 10:14:47 -06:00
|
|
|
@pytest.mark.sphinx(
|
2017-12-13 08:48:07 -06:00
|
|
|
testroot='theming',
|
2017-01-05 10:14:47 -06:00
|
|
|
confoverrides={'html_theme': 'ziptheme',
|
|
|
|
'html_theme_options.testopt': 'foo'})
|
2014-09-21 10:17:02 -05:00
|
|
|
def test_theme_api(app, status, warning):
|
2009-02-15 09:10:10 -06:00
|
|
|
cfg = app.config
|
|
|
|
|
2018-06-19 07:58:06 -05:00
|
|
|
themes = ['basic', 'default', 'scrolls', 'agogo', 'sphinxdoc', 'haiku',
|
|
|
|
'traditional', 'epub', 'nature', 'pyramid', 'bizstyle', 'classic', 'nonav',
|
|
|
|
'test-theme', 'ziptheme', 'staticfiles', 'parent', 'child']
|
2023-04-26 11:04:48 -05:00
|
|
|
try:
|
|
|
|
alabaster_version = alabaster.__version_info__
|
|
|
|
except AttributeError:
|
|
|
|
alabaster_version = alabaster.version.__version_info__
|
|
|
|
if alabaster_version >= (0, 7, 11):
|
2018-06-19 07:58:06 -05:00
|
|
|
themes.append('alabaster')
|
|
|
|
|
2009-02-15 09:10:10 -06:00
|
|
|
# test Theme class API
|
2021-12-10 19:52:22 -06:00
|
|
|
assert set(app.registry.html_themes.keys()) == set(themes)
|
2023-07-27 18:39:12 -05:00
|
|
|
assert app.registry.html_themes['test-theme'] == str(app.srcdir / 'test_theme' / 'test-theme')
|
|
|
|
assert app.registry.html_themes['ziptheme'] == str(app.srcdir / 'ziptheme.zip')
|
|
|
|
assert app.registry.html_themes['staticfiles'] == str(app.srcdir / 'test_theme' / 'staticfiles')
|
2009-02-15 09:10:10 -06:00
|
|
|
|
|
|
|
# test Theme instance API
|
|
|
|
theme = app.builder.theme
|
|
|
|
assert theme.name == 'ziptheme'
|
|
|
|
themedir = theme.themedir
|
|
|
|
assert theme.base.name == 'basic'
|
2017-04-20 09:38:48 -05:00
|
|
|
assert len(theme.get_theme_dirs()) == 2
|
2009-02-15 09:10:10 -06:00
|
|
|
|
|
|
|
# direct setting
|
2017-04-20 09:38:48 -05:00
|
|
|
assert theme.get_config('theme', 'stylesheet') == 'custom.css'
|
2009-02-15 09:10:10 -06:00
|
|
|
# inherited setting
|
2017-04-20 09:38:48 -05:00
|
|
|
assert theme.get_config('options', 'nosidebar') == 'false'
|
2009-02-15 09:10:10 -06:00
|
|
|
# nonexisting setting
|
2017-04-20 09:38:48 -05:00
|
|
|
assert theme.get_config('theme', 'foobar', 'def') == 'def'
|
2017-01-05 09:46:42 -06:00
|
|
|
with pytest.raises(ThemeError):
|
2017-04-20 09:38:48 -05:00
|
|
|
theme.get_config('theme', 'foobar')
|
2009-02-15 09:10:10 -06:00
|
|
|
|
|
|
|
# options API
|
2017-06-26 02:17:08 -05:00
|
|
|
|
|
|
|
options = theme.get_options({'nonexisting': 'foo'})
|
|
|
|
assert 'nonexisting' not in options.keys()
|
|
|
|
|
2009-02-15 09:10:10 -06:00
|
|
|
options = theme.get_options(cfg.html_theme_options)
|
|
|
|
assert options['testopt'] == 'foo'
|
|
|
|
assert options['nosidebar'] == 'false'
|
|
|
|
|
|
|
|
# cleanup temp directories
|
|
|
|
theme.cleanup()
|
|
|
|
assert not os.path.exists(themedir)
|
2014-06-07 04:32:56 -05:00
|
|
|
|
2014-09-21 10:17:02 -05:00
|
|
|
|
2017-01-05 10:14:47 -06:00
|
|
|
@pytest.mark.sphinx(testroot='double-inheriting-theme')
|
2017-04-20 00:04:49 -05:00
|
|
|
def test_double_inheriting_theme(app, status, warning):
|
|
|
|
assert app.builder.theme.name == 'base_theme2'
|
|
|
|
app.build() # => not raises TemplateNotFound
|
2017-04-18 09:22:03 -05:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.sphinx(testroot='theming',
|
|
|
|
confoverrides={'html_theme': 'child'})
|
|
|
|
def test_nested_zipped_theme(app, status, warning):
|
2017-04-20 00:04:49 -05:00
|
|
|
assert app.builder.theme.name == 'child'
|
2017-04-18 09:22:03 -05:00
|
|
|
app.build() # => not raises TemplateNotFound
|
2017-10-22 01:12:31 -05:00
|
|
|
|
|
|
|
|
2017-12-13 08:48:07 -06:00
|
|
|
@pytest.mark.sphinx(testroot='theming',
|
|
|
|
confoverrides={'html_theme': 'staticfiles'})
|
|
|
|
def test_staticfiles(app, status, warning):
|
|
|
|
app.build()
|
|
|
|
assert (app.outdir / '_static' / 'staticimg.png').exists()
|
|
|
|
assert (app.outdir / '_static' / 'statictmpl.html').exists()
|
2022-04-26 21:04:19 -05:00
|
|
|
assert (app.outdir / '_static' / 'statictmpl.html').read_text(encoding='utf8') == (
|
2017-12-13 08:48:07 -06:00
|
|
|
'<!-- testing static templates -->\n'
|
|
|
|
'<html><project>Python</project></html>'
|
|
|
|
)
|
|
|
|
|
2022-04-26 21:04:19 -05:00
|
|
|
result = (app.outdir / 'index.html').read_text(encoding='utf8')
|
2017-12-13 08:48:07 -06:00
|
|
|
assert '<meta name="testopt" content="optdefault" />' in result
|
2017-12-15 09:53:55 -06:00
|
|
|
|
|
|
|
|
2020-03-14 12:46:02 -05:00
|
|
|
@pytest.mark.sphinx(testroot='theming',
|
|
|
|
confoverrides={'html_theme': 'test-theme'})
|
2023-08-07 15:02:25 -05:00
|
|
|
def test_dark_style(app, monkeypatch):
|
|
|
|
monkeypatch.setattr(sphinx.builders.html, '_file_checksum', lambda o, f: '')
|
|
|
|
|
2020-03-14 12:49:25 -05:00
|
|
|
style = app.builder.dark_highlighter.formatter_args.get('style')
|
2020-03-14 12:46:02 -05:00
|
|
|
assert style.__name__ == 'MonokaiStyle'
|
|
|
|
|
|
|
|
app.build()
|
|
|
|
assert (app.outdir / '_static' / 'pygments_dark.css').exists()
|
|
|
|
|
2023-08-07 15:02:25 -05:00
|
|
|
css_file, properties = app.registry.css_files[0]
|
|
|
|
assert css_file == 'pygments_dark.css'
|
|
|
|
assert "media" in properties
|
|
|
|
assert properties["media"] == '(prefers-color-scheme: dark)'
|
|
|
|
|
2023-08-11 19:46:44 -05:00
|
|
|
assert sorted(f.filename for f in app.builder._css_files) == [
|
2023-08-07 15:02:25 -05:00
|
|
|
'_static/classic.css',
|
|
|
|
'_static/pygments.css',
|
|
|
|
'_static/pygments_dark.css',
|
|
|
|
]
|
|
|
|
|
2022-04-26 21:04:19 -05:00
|
|
|
result = (app.outdir / 'index.html').read_text(encoding='utf8')
|
2023-08-07 15:02:25 -05:00
|
|
|
assert '<link rel="stylesheet" type="text/css" href="_static/pygments.css" />' in result
|
2020-03-14 13:46:37 -05:00
|
|
|
assert ('<link id="pygments_dark_css" media="(prefers-color-scheme: dark)" '
|
|
|
|
'rel="stylesheet" type="text/css" '
|
2023-08-07 15:02:25 -05:00
|
|
|
'href="_static/pygments_dark.css" />') in result
|
2020-03-14 12:46:02 -05:00
|
|
|
|
|
|
|
|
2017-10-22 01:12:31 -05:00
|
|
|
@pytest.mark.sphinx(testroot='theming')
|
|
|
|
def test_theme_sidebars(app, status, warning):
|
|
|
|
app.build()
|
|
|
|
|
|
|
|
# test-theme specifies globaltoc and searchbox as default sidebars
|
2022-04-26 21:04:19 -05:00
|
|
|
result = (app.outdir / 'index.html').read_text(encoding='utf8')
|
2018-07-21 16:13:16 -05:00
|
|
|
assert '<h3><a href="#">Table of Contents</a></h3>' in result
|
2017-10-22 01:12:31 -05:00
|
|
|
assert '<h3>Related Topics</h3>' not in result
|
|
|
|
assert '<h3>This Page</h3>' not in result
|
2019-04-22 05:55:32 -05:00
|
|
|
assert '<h3 id="searchlabel">Quick search</h3>' in result
|