Skip to content

Commit

Permalink
Tmp commit
Browse files Browse the repository at this point in the history
  • Loading branch information
Kramer, Rudi committed Mar 11, 2019
1 parent e4ee877 commit d11d633
Showing 1 changed file with 7 additions and 7 deletions.
14 changes: 7 additions & 7 deletions src/supermarket/spec/helpers/markdown_helper_spec.rb
Expand Up @@ -13,7 +13,7 @@
```
CODEBLOCK

expect(helper.render_markdown(codeblock)).to match(/<pre><code>/)
expect(helper.render_markdown(codeblock)).to match(/<pre lang="sh"><code>/)
end

it 'auto renders links with target blank' do
Expand Down Expand Up @@ -57,12 +57,12 @@
context 'protocol in URLs for images get converted' do
it 'HTTP -> protocol-relative' do
html = helper.render_markdown('![](http://img.example.com)')
expect(html).to include('<img src="//img.example.com" alt="">')
expect(html).to include('src="//img.example.com"')
end

it 'HTTPS -> protocol-relative' do
html = helper.render_markdown('![](https://img.example.com)')
expect(html).to include('<img src="//img.example.com" alt="">')
expect(html).to include('src="//img.example.com"')
end
end

Expand All @@ -72,7 +72,7 @@

it 'escapes bare-html iframes' do
html = helper.render_markdown("<iframe src=javascript:alert('hahaha')></iframe>")
expect(html).to include("<p>&lt;iframe")
expect(html).to include("&lt;iframe")
end

it 'renders only one link when there is a link within a link' do
Expand Down Expand Up @@ -128,7 +128,7 @@
describe "with miscellaneous payloads" do
it "escapes bracketed javascript" do
html = helper.render_markdown("<javascript:prompt(document.cookie)>")
expect(html).to include("<p>&lt;javascript:prompt(document.cookie)&gt;</p>")
expect(html).to include("<a target=\"_blank\">javascript:prompt(document.cookie)</a>")
end

it "escapes unicode shenanigans" do
Expand All @@ -138,7 +138,7 @@

it "does not link with a javascript: scheme even though a URL is detected" do
html = helper.render_markdown("[link text](javascript://www.google.com%0Aprompt(1))")
expect(html).to include('<p>[link text](javascript://<a href="http://www.google.com%0Aprompt(1)"')
expect(html).to_not include('javascript://')
end

it "dodges footnote shenanigans by not parsing citations into links" do
Expand All @@ -157,7 +157,7 @@
it "prevents URL & email detection combining with emphasis, does not put base64 shenanigans into the link" do
payload = "_http://example_@.1 style=background-image:url();background-repeat:no-repeat;display:block;width:100%;height:100px; onclick=alert(unescape(/Oh%20No!/.source));return(false);//"
html = helper.render_markdown(payload)
expect(html).to include('<p><em><a href="http://example" target="_blank">http://example</a></em>@.1 style=background-image:url();background-repeat:no-repeat;display:block;width:100%;height:100px; onclick=alert(unescape(/Oh%20No!/.source));return(false);//</p>')
expect(html).to include('<p><em>http://example</em>@.1 style=background-image:url();background-repeat:no-repeat;display:block;width:100%;height:100px; onclick=alert(unescape(/Oh%20No!/.source));return(false);//</p>')
end

it "escapes brackets to prevent meta tag manipulation" do
Expand Down

1 comment on commit d11d633

@Rudikza
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

  1. Quite a few of the tests were very specific on their regex which cause them to fail. For instance, trying to match <img src=\"//img.example.com\" alt=\"\"> but the gfm changes the html to <img src=\"//img.example.com\" alt=\"\" style=\"max-width:100%;\"></a></p>" .

Fixing the above issues was pretty simple and get us down to 5 failing tests.

  1. There is one line in the payloads array javascript:alert&#65534;(1&#41; which passes through the first filter, the MarkdownFilter, and is converted to "<p>[a](javascript:alert\xFE(1))</p>". The \xFE is not valid utf-8 so it fails on the very next filter and the tests also fail with an invalid utf-8 error. I fired up a supermarket server on my local machine and the page fails to load with the same invalid UTF-8 error message.

This accounts for 2 failing tests and I have no idea how to tackle this one. One train of thought is that if people are messing around with javascript encoding and their supermarket page doesn't display it's their own fault but it could reflect badly on Chef so I'm not sure...

  1. Next we have two failling tests where the html pipeline creates links using &#x6A&#x61&#x76&#x61&#x73&#x63&#x7 as the link:
  1. MarkdownHelper to prevent XSS attacks does not render an HTML anchor for link text
    Failure/Error: expect(helper.render_markdown("a")).not_to match(/<a href/)

    expected "

    <a href="&#x6A&#x61&#x76&#x61&#x73&#x63&#x72&#x69&#x70&#...p;#x74&#x28&#x27&#x58&#x53&#x53&#x27&#x29" target="_blank">a

    " not to match /<a href/
    Diff:
    @@ -1,2 +1,2 @@
    -/<a href/
    +"

    <a href="&#x6A&#x61&#x76&#x61&#x73&#x63&#x72&#x69&#x70&#x74&#x3A&#x61&#x6C&#x65&#x72&#x74&#x28&#x27&#x58&#x53&#x53&#x27&#x29" target="_blank">a

    "

Even though it creates the link it doesn't function as a javascript function. When I tested it on my local server it created the following link localhost:3000/cookbooks/&#x6A&#x61&#x76&#x61&#x73&#x63&#x72&#x69&#x70&#x74&#x3A&#x61&#x6C&#x65&#x72&#x74&#x28&#x27&#x58&#x53&#x53&#x27&#x29 which does't go anywhere or call any js.

This makes me think that we need to change these two tests to match the behaviour of the markdown_renderer.

4.The last falling test is MarkdownHelper to prevent XSS attacks does not render an HTML img tag for funky alt text.

The tests expect the helper not to generate <img src but the helper does. I've tested against the demo app and even though it generates the src <img src="x" alt="alt text'&quot;onerror=prompt(document.cookie)" style="max-width:100%;">` The dodgy alt text is displayed and not run.

Please sign in to comment.