diff options
| author | Dan Allen <dallen@redhat.com> | 2013-04-24 04:25:00 -0600 |
|---|---|---|
| committer | Dan Allen <dallen@redhat.com> | 2013-04-25 13:22:58 -0600 |
| commit | 51b14a34ecb0178c914ced0f653b92adfb321713 (patch) | |
| tree | 937ba48ebe967322b783c46f89c74aeecd71b2a1 /test/paths_test.rb | |
| parent | 336bc05c142ada953c0022c7034d49eb0cce1ced (diff) | |
resolves #76 add a default stylesheet
- add a default stylesheet, asciidoctor.css, to stylesheets directory
- add copycss attribute to control copying default stylesheet to outdir
- add linkcss attribute to control stylesheet embedding
- use default stylesheet by default w/ linkcss enabled
- rewrite path logic to be more secure, deterministic and OS independent
- switch all path resolution to use new path resolver
- add path resolver tests
- refactor cli invoker to use render API
- add timing monitor to load and render APIs
- fix image path resolution to be secure
- add tests for embedded attribute
Diffstat (limited to 'test/paths_test.rb')
| -rw-r--r-- | test/paths_test.rb | 174 |
1 files changed, 174 insertions, 0 deletions
diff --git a/test/paths_test.rb b/test/paths_test.rb new file mode 100644 index 00000000..e5b91663 --- /dev/null +++ b/test/paths_test.rb @@ -0,0 +1,174 @@ +require 'test_helper' + +context 'Path Resolver' do + context 'Web Paths' do + def setup + @resolver = Asciidoctor::PathResolver.new + end + + test 'target with absolute path' do + assert_equal '/images', @resolver.web_path('/images') + assert_equal '/images', @resolver.web_path('/images', '') + assert_equal '/images', @resolver.web_path('/images', nil) + end + + test 'target with relative path' do + assert_equal 'images', @resolver.web_path('images') + assert_equal 'images', @resolver.web_path('images', '') + assert_equal 'images', @resolver.web_path('images', nil) + end + + test 'target with path relative to current directory' do + assert_equal './images', @resolver.web_path('./images') + assert_equal './images', @resolver.web_path('./images', '') + assert_equal './images', @resolver.web_path('./images', nil) + end + + test 'target with absolute path ignores start path' do + assert_equal '/images', @resolver.web_path('/images', 'foo') + assert_equal '/images', @resolver.web_path('/images', '/foo') + assert_equal '/images', @resolver.web_path('/images', './foo') + end + + test 'target with relative path appended to start path' do + assert_equal 'assets/images', @resolver.web_path('images', 'assets') + assert_equal '/assets/images', @resolver.web_path('images', '/assets') + assert_equal './assets/images', @resolver.web_path('images', './assets') + end + + test 'target with path relative to current directory appended to start path' do + assert_equal 'assets/images', @resolver.web_path('./images', 'assets') + assert_equal '/assets/images', @resolver.web_path('./images', '/assets') + assert_equal './assets/images', @resolver.web_path('./images', './assets') + end + + test 'normalize target' do + assert_equal '../images', @resolver.web_path('../images/../images') + end + + test 'append target to start path and normalize' do + assert_equal '../images', @resolver.web_path('../images/../images', '../images') + assert_equal '../../images', @resolver.web_path('../images', '..') + end + + test 'normalize parent directory that follows root' do + assert_equal '/tiger.png', @resolver.web_path('/../tiger.png') + assert_equal '/tiger.png', @resolver.web_path('/../../tiger.png') + end + + test 'uses start when target is empty' do + assert_equal 'assets/images', @resolver.web_path('', 'assets/images') + assert_equal 'assets/images', @resolver.web_path(nil, 'assets/images') + end + + test 'posixfies windows paths' do + assert_equal '/images', @resolver.web_path('\\images') + assert_equal '../images', @resolver.web_path('..\\images') + assert_equal '/images', @resolver.web_path('\\..\\images') + assert_equal 'assets/images', @resolver.web_path('assets\\images') + assert_equal '../assets/images', @resolver.web_path('assets\\images', '..\\images\\..') + end + end + + context 'System Paths' do + JAIL = '/home/doctor/docs' + + def setup + @resolver = Asciidoctor::PathResolver.new + end + + test 'prevents access to paths outside of jail' do + assert_equal "#{JAIL}/css", @resolver.system_path('../../../../../css', "#{JAIL}/assets/stylesheets", JAIL) + assert_equal "#{JAIL}/css", @resolver.system_path('/../../../../../css', "#{JAIL}/assets/stylesheets", JAIL) + assert_equal "#{JAIL}/css", @resolver.system_path('../../../css', '../../..', JAIL) + end + + test 'throws exception for illegal path access if recover is false' do + begin + @resolver.system_path('../../../../../css', "#{JAIL}/assets/stylesheets", JAIL, :recover => false) + flunk 'Expecting SecurityError to be raised' + rescue SecurityError + end + end + + test 'resolves start path if target is empty' do + assert_equal "#{JAIL}/assets/stylesheets", @resolver.system_path('', "#{JAIL}/assets/stylesheets", JAIL) + assert_equal "#{JAIL}/assets/stylesheets", @resolver.system_path(nil, "#{JAIL}/assets/stylesheets", JAIL) + end + + test 'resolves start path if target is dot' do + assert_equal "#{JAIL}/assets/stylesheets", @resolver.system_path('.', "#{JAIL}/assets/stylesheets", JAIL) + assert_equal "#{JAIL}/assets/stylesheets", @resolver.system_path('./', "#{JAIL}/assets/stylesheets", JAIL) + end + + test 'treats absolute target as relative when jail is specified' do + assert_equal "#{JAIL}/assets/stylesheets", @resolver.system_path('/', "#{JAIL}/assets/stylesheets", JAIL) + assert_equal "#{JAIL}/assets/stylesheets/foo", @resolver.system_path('/foo', "#{JAIL}/assets/stylesheets", JAIL) + assert_equal "#{JAIL}/assets/foo", @resolver.system_path('/../foo', "#{JAIL}/assets/stylesheets", JAIL) + end + + test 'allows use of absolute target or start if resolved path is sub-path of jail' do + assert_equal "#{JAIL}/my/path", @resolver.system_path("#{JAIL}/my/path", '', JAIL) + assert_equal "#{JAIL}/my/path", @resolver.system_path("#{JAIL}/my/path", nil, JAIL) + assert_equal "#{JAIL}/my/path", @resolver.system_path('', "#{JAIL}/my/path", JAIL) + assert_equal "#{JAIL}/my/path", @resolver.system_path(nil, "#{JAIL}/my/path", JAIL) + assert_equal "#{JAIL}/my/path", @resolver.system_path('path', "#{JAIL}/my", JAIL) + end + + test 'uses jail path if start path is empty' do + assert_equal "#{JAIL}/images/tiger.png", @resolver.system_path('images/tiger.png', '', JAIL) + assert_equal "#{JAIL}/images/tiger.png", @resolver.system_path('images/tiger.png', nil, JAIL) + end + + test 'raises security error if start is not contained within jail' do + begin + @resolver.system_path('images/tiger.png', '/etc', JAIL) + flunk 'Expecting SecurityError to be raised' + rescue SecurityError + end + + begin + @resolver.system_path('.', '/etc', JAIL) + flunk 'Expecting SecurityError to be raised' + rescue SecurityError + end + end + + test 'resolves absolute directory if jail is not specified' do + assert_equal '/usr/share/stylesheet.css', @resolver.system_path('/usr/share/stylesheet.css', '/home/dallen/docs/assets/stylesheets') + end + + test 'resolves ancestor directory of start if jail is not specified' do + assert_equal '/usr/share/stylesheet.css', @resolver.system_path('../../../../../usr/share/stylesheet.css', '/home/dallen/docs/assets/stylesheets') + end + + test 'resolves absolute path if start is absolute and target is relative' do + assert_equal '/usr/share/assets/stylesheet.css', @resolver.system_path('assets/stylesheet.css', '/usr/share') + end + + test 'resolves relative target relative to current directory if start is empty' do + pwd = File.expand_path(Dir.pwd) + assert_equal "#{pwd}/images/tiger.png", @resolver.system_path('images/tiger.png', '') + assert_equal "#{pwd}/images/tiger.png", @resolver.system_path('images/tiger.png', nil) + end + + test 'resolves and normalizes start with target is empty' do + pwd = File.expand_path(Dir.pwd) + assert_equal '/home/doctor/docs', @resolver.system_path('', '/home/doctor/docs') + assert_equal '/home/doctor/docs', @resolver.system_path(nil, '/home/doctor/docs') + assert_equal "#{pwd}/assets/images", @resolver.system_path(nil, 'assets/images') + assert_equal "#{JAIL}/assets/images", @resolver.system_path('', '../assets/images', JAIL) + end + + test 'posixfies windows paths' do + assert_equal "#{JAIL}/assets/css", @resolver.system_path('..\\css', 'assets\\stylesheets', JAIL) + end + + test 'resolves windows paths when file separator is backlash' do + @resolver.file_separator = '\\' + assert_equal 'C:\\data\\docs', @resolver.system_path('..', "C:\\data\\docs\\assets", 'C:\\data\\docs') + assert_equal 'C:\\data\\docs', @resolver.system_path('..\\..', "C:\\data\\docs\\assets", 'C:\\data\\docs') + assert_equal 'C:\\data\\docs\\css', @resolver.system_path('..\\..\\css', "C:\\data\\docs\\assets", 'C:\\data\\docs') + end + end +end |
