summaryrefslogtreecommitdiffstats
path: root/t/100markdown.t
blob: 217912bf90dbd5d393e883923c657ab431001b71 (plain)
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
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
# This Source Code Form is subject to the terms of the Mozilla Public
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
#
# This Source Code Form is "Incompatible With Secondary Licenses", as
# defined by the Mozilla Public License, v. 2.0.

# Enforce high standards against code that will be installed

use 5.14.0;
use strict;
use warnings;

use lib qw(. lib local/lib/perl5 t);
use Test2::Tools::Mock;
use Test::More;
use Bugzilla::Util;
BEGIN {
    my $terms = {
        "bug"               => "bug",
        "Bug"               => "Bug",
        "abug"              => "a bug",
        "Abug"              => "A bug",
        "aBug"              => "a Bug",
        "ABug"              => "A Bug",
        "bugs"              => "bugs",
        "Bugs"              => "Bugs",
        "comment"           => "comment",
        "comments"          => "comments",
        "zeroSearchResults" => "Zarro Boogs found",
        "Bugzilla"          => "Bugzilla"
    };
    no warnings 'redefine', 'once';
    *Bugzilla::Util::template_var = sub {
        my $name = shift;
        if ($name eq 'terms') {
            return $terms;
        } else {
            die "sorry!";
        }
    };
}
use Bugzilla;
use Bugzilla::Constants;
use Bugzilla::Bug;
use Bugzilla::Comment;
use Bugzilla::User;
use Bugzilla::Markdown;
use Bugzilla::Util;
use File::Basename;

Bugzilla->usage_mode(USAGE_MODE_TEST);
Bugzilla->error_mode(ERROR_MODE_DIE);

my $user_mock = mock 'Bugzilla::User' => (
    override_constructor => ['new', 'hash'],
);

my $comment_mock = mock 'Bugzilla::Comment' => (
    add_constructor => ['new', 'hash'],
);

my $bug_mock = mock 'Bugzilla::Bug' => (
    override_constructor => ['new', 'hash'],
);

# mocked objects just take all constructor args and put them into the hash.
my $user = Bugzilla::User->new(
    userid => 33,
    settings => { use_markdown => { is_enabled => 1, value => 'on' } },
);
my $bug = Bugzilla::Bug->new(bug_id => 666);
my $comment = Bugzilla::Comment->new(already_wrapped => 0);

Bugzilla->set_user($user);

my @testfiles = glob("t/markdown/*.md");

plan(tests => scalar(@testfiles) + 1);

my $markdown = Bugzilla::Markdown->new();
ok($markdown, "got a new markdown object");

foreach my $testfile (@testfiles) {
  my $data = read_text($testfile);

  my ($markdown_text, $expected_html) = split(/---/, $data);
  $markdown_text = trim($markdown_text);
  $expected_html = trim($expected_html);

  my $actual_html = $markdown->markdown($markdown_text, $bug, $comment);
  $actual_html = trim($actual_html);

  is($actual_html, $expected_html, basename($testfile));
}

done_testing();