-- Test for 'lisp'
-- If the lisp feature is not enabled, this will fail!
local n = require('test.functional.testnvim')()
local clear, feed, insert = n.clear, n.feed, n.insert
local command, expect = n.command, n.expect
local poke_eventloop = n.poke_eventloop
describe('lisp indent', function()
  setup(clear)
  -- luacheck: ignore 621 (Indentation)
  it('is working', function()
    insert([[
      (defun html-file (base)
      (format nil "~(~A~).html" base))
      (defmacro page (name title &rest body)
      (let ((ti (gensym)))
      `(with-open-file (*standard-output*
      (html-file ,name)
      :direction :output
      :if-exists :supersede)
      (let ((,ti ,title))
      (as title ,ti)
      (with center
      (as h2 (string-upcase ,ti)))
      (brs 3)
      ,@body))))
      ;;; Utilities for generating links
      (defmacro with-link (dest &rest body)
      `(progn
      (format t "" (html-file ,dest))
      ,@body
      (princ "")))]])
    command('set lisp')
    command('/^(defun')
    feed('=G:/^(defun/,$yank A')
    poke_eventloop()
    -- Put @a and clean empty line
    command('%d')
    command('0put a')
    command('$d')
    -- Assert buffer contents.
    expect([[
      (defun html-file (base)
        (format nil "~(~A~).html" base))
      (defmacro page (name title &rest body)
        (let ((ti (gensym)))
          `(with-open-file (*standard-output*
      		       (html-file ,name)
      		       :direction :output
      		       :if-exists :supersede)
             (let ((,ti ,title))
      	 (as title ,ti)
      	 (with center
      	       (as h2 (string-upcase ,ti)))
      	 (brs 3)
      	 ,@body))))
      ;;; Utilities for generating links
      (defmacro with-link (dest &rest body)
        `(progn
           (format t "" (html-file ,dest))
           ,@body
           (princ "")))]])
  end)
end)