File: stress.lisp

package info (click to toggle)
cl-esrap 20211008.gitc99c33a-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 516 kB
  • sloc: lisp: 4,873; makefile: 51; sh: 7
file content (44 lines) | stat: -rw-r--r-- 1,992 bytes parent folder | download | duplicates (2)
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
;;;; Copyright (c) 2019 Jan Moringen <jmoringe@techfak.uni-bielefeld.de>
;;;;
;;;; Permission is hereby granted, free of charge, to any person
;;;; obtaining a copy of this software and associated documentation files
;;;; (the "Software"), to deal in the Software without restriction,
;;;; including without limitation the rights to use, copy, modify, merge,
;;;; publish, distribute, sublicense, and/or sell copies of the Software,
;;;; and to permit persons to whom the Software is furnished to do so,
;;;; subject to the following conditions:
;;;;
;;;; THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
;;;; EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
;;;; MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
;;;; IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
;;;; CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
;;;; TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
;;;; SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

(cl:in-package #:esrap-tests)

(in-suite esrap)

(test long-input
  "Inputs of various lengths that stress the chunk cache."
  (loop :for length :from 0 :to 5000
        :do (let* ((input (make-string length :initial-element #\a))
                   (result (esrap:parse '(* #\a) input)))
              (is (eql length (length result))))))

(macrolet ((define-rules ()
             (let ((names '()))
              `(progn
                 ,@(loop :for i :from 0 :to (1+ esrap::+packrat-hash-table-switch-point+)
                         :for string = (format nil "~R" i)
                         :for name = (intern string)
                         :do (push name names)
                         :collect `(defrule ,name ,string))
                 (defrule number
                     (or ,@names))))))
  (define-rules))

(test many-rules
  "Many alternative rules that stress the packrat cache."
  (is (equal "zero" (parse 'number "zero"))))