summaryrefslogtreecommitdiff
path: root/mut/neovim/pack/plugins/start/quicker.nvim/tests/display_spec.lua
blob: c3404adb1ae804b334701440f0153478ee82d90a (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
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
require("plenary.async").tests.add_to_env()
local config = require("quicker.config")
local test_util = require("tests.test_util")

local sleep = require("plenary.async.util").sleep

a.describe("display", function()
  after_each(function()
    test_util.reset_editor()
  end)

  it("renders quickfix items", function()
    vim.fn.setqflist({
      {
        bufnr = vim.fn.bufadd("README.md"),
        text = "text",
        lnum = 5,
        valid = 1,
      },
      {
        filename = "README.md",
        text = "text",
        lnum = 10,
        col = 0,
        end_col = 4,
        nr = 3,
        type = "E",
        valid = 1,
      },
      {
        module = "mod",
        bufnr = vim.fn.bufadd("README.md"),
        text = "text",
        valid = 1,
      },
      {
        bufnr = vim.fn.bufadd("README.md"),
        text = "text",
        valid = 0,
      },
      {
        bufnr = vim.fn.bufadd("README.md"),
        lnum = 1,
        text = "",
        valid = 0,
      },
    })
    vim.cmd.copen()
    test_util.assert_snapshot(0, "display_1")
  end)

  a.it("truncates long filenames", function()
    config.max_filename_width = function()
      return 10
    end
    local bufnr = vim.fn.bufadd(test_util.make_tmp_file(string.rep("f", 10) .. ".txt", 10))
    vim.fn.setqflist({
      {
        bufnr = bufnr,
        text = "text",
        lnum = 5,
        valid = 1,
      },
    })
    vim.cmd.copen()
    -- Wait for highlights to be applied
    sleep(50)
    test_util.assert_snapshot(0, "display_long_1")
  end)

  a.it("renders minimal line when no filenames in results", function()
    vim.fn.setqflist({
      {
        text = "text",
      },
    })
    vim.cmd.copen()
    -- Wait for highlights to be applied
    sleep(50)
    test_util.assert_snapshot(0, "display_minimal_1")
  end)

  a.it("sets signs for diagnostics", function()
    local bufnr = vim.fn.bufadd(test_util.make_tmp_file("sign_test.txt", 10))
    vim.fn.setqflist({
      {
        bufnr = bufnr,
        text = "text",
        lnum = 1,
        type = "E",
        valid = 1,
      },
      {
        bufnr = bufnr,
        text = "text",
        lnum = 2,
        type = "W",
        valid = 1,
      },
      {
        bufnr = bufnr,
        text = "text",
        lnum = 3,
        type = "I",
        valid = 1,
      },
      {
        bufnr = bufnr,
        text = "text",
        lnum = 4,
        type = "H",
        valid = 1,
      },
      {
        bufnr = bufnr,
        text = "text",
        lnum = 5,
        type = "N",
        valid = 1,
      },
    })
    vim.cmd.copen()

    -- Wait for highlights to be applied
    sleep(50)
    local ns = vim.api.nvim_create_namespace("quicker_highlights")
    local marks = vim.api.nvim_buf_get_extmarks(0, ns, 0, -1, { type = "sign" })
    assert.equals(5, #marks)
    local expected = {
      { "DiagnosticSignError", config.type_icons.E },
      { "DiagnosticSignWarn", config.type_icons.W },
      { "DiagnosticSignInfo", config.type_icons.I },
      { "DiagnosticSignHint", config.type_icons.H },
      { "DiagnosticSignHint", config.type_icons.N },
    }
    for i, mark_data in ipairs(marks) do
      local extmark_id, row = mark_data[1], mark_data[2]
      local mark = vim.api.nvim_buf_get_extmark_by_id(0, ns, extmark_id, { details = true })
      local hl_group, icon = unpack(expected[i])
      assert.equals(i - 1, row)
      assert.equals(hl_group, mark[3].sign_hl_group)
      assert.equals(icon, mark[3].sign_text)
    end
  end)
end)