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 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75
|
# -*- coding: utf-8 -*- #
# frozen_string_literal: true
require 'rouge/plugins/redcarpet'
describe Rouge::Plugins::Redcarpet do
# skip if redcarpet isn't loaded
next unless Object.const_defined? :Redcarpet
let(:redcarpet) {
Class.new(Redcarpet::Render::HTML) do
include Rouge::Plugins::Redcarpet
end
}
let(:markdown) {
Redcarpet::Markdown.new(redcarpet.new, :fenced_code_blocks => true)
}
it 'renders a thing' do
result = markdown.render <<-mkd
``` javascript
var foo = 1;
```
``` shell
foo=1
```
mkd
assert { result.include?(%(<pre class="highlight shell"><code>)) }
assert { result.include?(%(<pre class="highlight javascript"><code>)) }
end
it 'guesses' do
result = markdown.render <<-mkd
``` guess
#!/usr/bin/env ruby
puts "hello, world"
```
mkd
assert { result.include?(%(<pre class="highlight ruby"><code>)) }
end
it 'chooses when a guess is ambiguous' do
result = markdown.render <<-mkd
``` guess
Index: ): Awaitable<
```
mkd
assert { result.include?(%(<pre class="highlight)) }
end
it 'passes options' do
result = markdown.render <<-mkd
``` shell?k=v
foo=1
```
mkd
# TODO: test that an option is actually there
assert { result.include?(%(<pre class="highlight shell"><code>)) }
end
it 'works when no language is provided' do
result = markdown.render <<-mkd
```
#!/usr/bin/env ruby
$stdin.each { |l| $stdout.puts l.reverse }
```
mkd
assert { result.include?(%(<pre class="highlight ruby"><code>)) }
end
end
|