Patch 8.2.1493
Problem:    Not enough test coverage for the spell file handling.
Solution:   Add spell file tests. (Yegappan Lakshmanan, closes #6728)
Files:      src/spellfile.c, src/testdir/test_spellfile.vim


*** ../vim-8.2.1492/src/spellfile.c     2020-07-10 20:03:00.539042582 +0200
--- src/spellfile.c     2020-08-20 15:40:05.709626391 +0200
***************
*** 519,525 ****
                lp->sl_syllable = read_string(fd, len); // <syllable>
                if (lp->sl_syllable == NULL)
                    goto endFAIL;
!               if (init_syl_tab(lp) == FAIL)
                    goto endFAIL;
                break;
  
--- 519,525 ----
                lp->sl_syllable = read_string(fd, len); // <syllable>
                if (lp->sl_syllable == NULL)
                    goto endFAIL;
!               if (init_syl_tab(lp) != OK)
                    goto endFAIL;
                break;
  
*** ../vim-8.2.1492/src/testdir/test_spellfile.vim      2020-08-16 
21:51:45.490384078 +0200
--- src/testdir/test_spellfile.vim      2020-08-20 15:40:05.709626391 +0200
***************
*** 171,339 ****
    bw!
  endfunc
  
! " Test for spell file format errors
  func Test_spellfile_format_error()
    let save_rtp = &rtp
    call mkdir('Xtest/spell', 'p')
  
    " empty spell file
!   call writefile([], './Xtest/spell/Xtest.utf-8.spl')
    set runtimepath=./Xtest
    set spelllang=Xtest
    call assert_fails('set spell', 'E757:')
    set nospell spelllang&
  
    " invalid file ID
!   call writefile(['vim'], './Xtest/spell/Xtest.utf-8.spl')
    set runtimepath=./Xtest
    set spelllang=Xtest
    call assert_fails('set spell', 'E757:')
    set nospell spelllang&
  
    " missing version number
!   call writefile(['VIMspell'], './Xtest/spell/Xtest.utf-8.spl')
    set runtimepath=./Xtest
    set spelllang=Xtest
    call assert_fails('set spell', 'E771:')
    set nospell spelllang&
  
    " invalid version number
!   call writefile(['VIMspellz'], './Xtest/spell/Xtest.utf-8.spl')
    set runtimepath=./Xtest
    set spelllang=Xtest
    call assert_fails('set spell', 'E772:')
    set nospell spelllang&
  
    " no sections
!   call writefile(0z56494D7370656C6C32, './Xtest/spell/Xtest.utf-8.spl', 'b')
!   set runtimepath=./Xtest
!   set spelllang=Xtest
!   call assert_fails('set spell', 'E758:')
!   set nospell spelllang&
  
    " missing section length
!   call writefile(['VIMspell200'], './Xtest/spell/Xtest.utf-8.spl')
!   set runtimepath=./Xtest
!   set spelllang=Xtest
!   call assert_fails('set spell', 'E758:')
!   set nospell spelllang&
  
    " unsupported required section
!   call writefile(['VIMspell2z' .. nr2char(1) .. '   ' .. nr2char(4)],
!         \ './Xtest/spell/Xtest.utf-8.spl')
!   set runtimepath=./Xtest
!   set spelllang=Xtest
!   call assert_fails('set spell', 'E770:')
!   set nospell spelllang&
  
    " unsupported not-required section
!   call writefile(['VIMspell2z' .. nr2char(0) .. '   ' .. nr2char(4)],
!         \ './Xtest/spell/Xtest.utf-8.spl')
!   set runtimepath=./Xtest
!   set spelllang=Xtest
!   call assert_fails('set spell', 'E758:')
!   set nospell spelllang&
  
    " SN_REGION: invalid number of region names
!   call writefile(0z56494D7370656C6C320000000000FF,
!         \ './Xtest/spell/Xtest.utf-8.spl', 'b')
!   set runtimepath=./Xtest
!   set spelllang=Xtest
!   call assert_fails('set spell', 'E759:')
!   set nospell spelllang&
  
    " SN_CHARFLAGS: missing <charflagslen> length
!   call writefile(0z56494D7370656C6C32010000000004,
!         \ './Xtest/spell/Xtest.utf-8.spl', 'b')
!   set runtimepath=./Xtest
!   set spelllang=Xtest
!   call assert_fails('set spell', 'E758:')
!   set nospell spelllang&
  
    " SN_CHARFLAGS: invalid <charflagslen> length
!   call writefile(0z56494D7370656C6C320100000000010201,
!         \ './Xtest/spell/Xtest.utf-8.spl', 'b')
!   set runtimepath=./Xtest
!   set spelllang=Xtest
!   set spell
!   " FIXME: There are no error messages. How to check for the test result?
!   set nospell spelllang&
  
    " SN_CHARFLAGS: charflagslen == 0 and folcharslen != 0
!   call writefile(0z56494D7370656C6C3201000000000400000101,
!         \ './Xtest/spell/Xtest.utf-8.spl', 'b')
!   set runtimepath=./Xtest
!   set spelllang=Xtest
!   call assert_fails('set spell', 'E759:')
!   set nospell spelllang&
  
    " SN_CHARFLAGS: missing <folcharslen> length
!   call writefile(0z56494D7370656C6C3201000000000100,
!         \ './Xtest/spell/Xtest.utf-8.spl', 'b')
!   set runtimepath=./Xtest
!   set spelllang=Xtest
!   call assert_fails('set spell', 'E758:')
!   set nospell spelllang&
  
    " SN_PREFCOND: invalid prefcondcnt
!   call writefile(0z56494D7370656C6C3203000000000100,
!         \ './Xtest/spell/Xtest.utf-8.spl', 'b')
!   set runtimepath=./Xtest
!   set spelllang=Xtest
!   call assert_fails('set spell', 'E759:')
!   set nospell spelllang&
  
    " SN_PREFCOND: invalid condlen
!   call writefile(0z56494D7370656C6C320300000000020001,
!         \ './Xtest/spell/Xtest.utf-8.spl', 'b')
    set runtimepath=./Xtest
    set spelllang=Xtest
!   call assert_fails('set spell', 'E759:')
    set nospell spelllang&
  
!   " SN_REP: invalid repcount
!   call writefile(0z56494D7370656C6C3204000000000100,
!         \ './Xtest/spell/Xtest.utf-8.spl', 'b')
    set runtimepath=./Xtest
    set spelllang=Xtest
!   call assert_fails('set spell', 'E758:')
    set nospell spelllang&
  
!   " SN_REP: missing rep
!   call writefile(0z56494D7370656C6C320400000000020004,
!         \ './Xtest/spell/Xtest.utf-8.spl', 'b')
    set runtimepath=./Xtest
    set spelllang=Xtest
!   call assert_fails('set spell', 'E758:')
    set nospell spelllang&
  
!   " SN_REP: zero repfromlen
!   call writefile(0z56494D7370656C6C32040000000003000100,
!         \ './Xtest/spell/Xtest.utf-8.spl', 'b')
    set runtimepath=./Xtest
    set spelllang=Xtest
!   call assert_fails('set spell', 'E759:')
    set nospell spelllang&
  
!   " SN_REP: invalid reptolen
!   call writefile(0z56494D7370656C6C320400000000050001014101,
!         \ './Xtest/spell/Xtest.utf-8.spl', 'b')
    set runtimepath=./Xtest
    set spelllang=Xtest
-   " FIXME: There are no error messages. How to check for the test result?
    set spell
    set nospell spelllang&
  
!   " SN_REP: zero reptolen
!   call writefile(0z56494D7370656C6C320400000000050001014100,
!         \ './Xtest/spell/Xtest.utf-8.spl', 'b')
    set runtimepath=./Xtest
    set spelllang=Xtest
!   call assert_fails('set spell', 'E759:')
    set nospell spelllang&
  
    let &rtp = save_rtp
    call delete('Xtest', 'rf')
  endfunc
  
  " vim: shiftwidth=2 sts=2 expandtab
--- 171,527 ----
    bw!
  endfunc
  
! " Spell file content test. Write 'content' to the spell file prefixed by the
! " spell file header and then enable spell checking. If 'emsg' is not empty,
! " then check for error.
! func Spellfile_Test(content, emsg)
!   let splfile = './Xtest/spell/Xtest.utf-8.spl'
!   " Add the spell file header and version (VIMspell2)
!   let v = 0z56494D7370656C6C32 + a:content
!   call writefile(v, splfile, 'b')
!   set runtimepath=./Xtest
!   set spelllang=Xtest
!   if a:emsg != ''
!     call assert_fails('set spell', a:emsg)
!   else
!     " FIXME: With some invalid spellfile contents, there are no error
!     " messages. So don't know how to check for the test result.
!     set spell
!   endif
!   set nospell spelllang& rtp&
! endfunc
! 
! " Test for spell file format errors.
! " The spell file format is described in spellfile.c
  func Test_spellfile_format_error()
    let save_rtp = &rtp
    call mkdir('Xtest/spell', 'p')
+   let splfile = './Xtest/spell/Xtest.utf-8.spl'
  
    " empty spell file
!   call writefile([], splfile)
    set runtimepath=./Xtest
    set spelllang=Xtest
    call assert_fails('set spell', 'E757:')
    set nospell spelllang&
  
    " invalid file ID
!   call writefile(0z56494D, splfile, 'b')
    set runtimepath=./Xtest
    set spelllang=Xtest
    call assert_fails('set spell', 'E757:')
    set nospell spelllang&
  
    " missing version number
!   call writefile(0z56494D7370656C6C, splfile, 'b')
    set runtimepath=./Xtest
    set spelllang=Xtest
    call assert_fails('set spell', 'E771:')
    set nospell spelllang&
  
    " invalid version number
!   call writefile(0z56494D7370656C6C7A, splfile, 'b')
    set runtimepath=./Xtest
    set spelllang=Xtest
    call assert_fails('set spell', 'E772:')
    set nospell spelllang&
  
    " no sections
!   call Spellfile_Test(0z, 'E758:')
  
    " missing section length
!   call Spellfile_Test(0z00, 'E758:')
  
    " unsupported required section
!   call Spellfile_Test(0z7A0100000004, 'E770:')
  
    " unsupported not-required section
!   call Spellfile_Test(0z7A0000000004, 'E758:')
  
    " SN_REGION: invalid number of region names
!   call Spellfile_Test(0z0000000000FF, 'E759:')
  
    " SN_CHARFLAGS: missing <charflagslen> length
!   call Spellfile_Test(0z010000000004, 'E758:')
  
    " SN_CHARFLAGS: invalid <charflagslen> length
!   call Spellfile_Test(0z0100000000010201, '')
  
    " SN_CHARFLAGS: charflagslen == 0 and folcharslen != 0
!   call Spellfile_Test(0z01000000000400000101, 'E759:')
  
    " SN_CHARFLAGS: missing <folcharslen> length
!   call Spellfile_Test(0z01000000000100, 'E758:')
  
    " SN_PREFCOND: invalid prefcondcnt
!   call Spellfile_Test(0z03000000000100, 'E759:')
  
    " SN_PREFCOND: invalid condlen
!   call Spellfile_Test(0z0300000000020001, 'E759:')
! 
!   " SN_REP: invalid repcount
!   call Spellfile_Test(0z04000000000100, 'E758:')
! 
!   " SN_REP: missing rep
!   call Spellfile_Test(0z0400000000020004, 'E758:')
! 
!   " SN_REP: zero repfromlen
!   call Spellfile_Test(0z040000000003000100, 'E759:')
! 
!   " SN_REP: invalid reptolen
!   call Spellfile_Test(0z0400000000050001014101, '')
! 
!   " SN_REP: zero reptolen
!   call Spellfile_Test(0z0400000000050001014100, 'E759:')
! 
!   " SN_SAL: missing salcount
!   call Spellfile_Test(0z05000000000102, 'E758:')
! 
!   " SN_SAL: missing salfromlen
!   call Spellfile_Test(0z050000000003080001, 'E758:')
! 
!   " SN_SAL: missing saltolen
!   call Spellfile_Test(0z0500000000050400010161, 'E758:')
! 
!   " SN_WORDS: non-NUL terminated word
!   call Spellfile_Test(0z0D000000000376696D, 'E758:')
! 
!   " SN_WORDS: very long word
!   let v = eval('0z0D000000012C' .. repeat('41', 300))
!   call Spellfile_Test(v, 'E759:')
! 
!   " SN_SOFO: missing sofofromlen
!   call Spellfile_Test(0z06000000000100, 'E758:')
! 
!   " SN_SOFO: missing sofotolen
!   call Spellfile_Test(0z06000000000400016100, 'E758:')
! 
!   " SN_SOFO: missing sofoto
!   call Spellfile_Test(0z0600000000050001610000, 'E759:')
! 
!   " SN_COMPOUND: compmax is less than 2
!   call Spellfile_Test(0z08000000000101, 'E759:')
! 
!   " SN_COMPOUND: missing compsylmax and other options
!   call Spellfile_Test(0z0800000000020401, 'E759:')
! 
!   " SN_COMPOUND: missing compoptions
!   call Spellfile_Test(0z080000000005040101, 'E758:')
! 
!   " SN_INFO: missing info
!   call Spellfile_Test(0z0F0000000005040101, '')
! 
!   " SN_MIDWORD: missing midword
!   call Spellfile_Test(0z0200000000040102, '')
! 
!   " SN_MAP: missing midword
!   call Spellfile_Test(0z0700000000040102, '')
! 
!   " SN_SYLLABLE: missing SYLLABLE item
!   call Spellfile_Test(0z0900000000040102, '')
! 
!   " SN_SYLLABLE: More than SY_MAXLEN size
!   let v = eval('0z090000000022612F' .. repeat('62', 32))
!   call Spellfile_Test(v, '')
! 
!   " LWORDTREE: missing
!   call Spellfile_Test(0zFF, 'E758:')
! 
!   " LWORDTREE: missing tree node
!   call Spellfile_Test(0zFF00000004, 'E758:')
! 
!   " LWORDTREE: missing tree node value
!   call Spellfile_Test(0zFF0000000402, 'E758:')
! 
!   " KWORDTREE: missing tree node
!   call Spellfile_Test(0zFF0000000000000004, 'E758:')
! 
!   " PREFIXTREE: missing tree node
!   call Spellfile_Test(0zFF000000000000000000000004, 'E758:')
! 
!   let &rtp = save_rtp
!   call delete('Xtest', 'rf')
! endfunc
! 
! " Test for format errors in suggest file
! func Test_sugfile_format_error()
!   let save_rtp = &rtp
!   call mkdir('Xtest/spell', 'p')
!   let splfile = './Xtest/spell/Xtest.utf-8.spl'
!   let sugfile = './Xtest/spell/Xtest.utf-8.sug'
! 
!   " create an empty spell file with a suggest timestamp
!   call 
writefile(0z56494D7370656C6C320B00000000080000000000000044FF000000000000000000000000,
 splfile, 'b')
! 
!   " 'encoding' is set before each test to clear the previously loaded suggest
!   " file from memory.
! 
!   " empty suggest file
!   set encoding=utf-8
!   call writefile([], sugfile)
    set runtimepath=./Xtest
    set spelllang=Xtest
!   set spell
!   call assert_fails("let s = spellsuggest('abc')", 'E778:')
    set nospell spelllang&
  
!   " zero suggest version
!   set encoding=utf-8
!   call writefile(0z56494D73756700, sugfile)
    set runtimepath=./Xtest
    set spelllang=Xtest
!   set spell
!   call assert_fails("let s = spellsuggest('abc')", 'E779:')
    set nospell spelllang&
  
!   " unsupported suggest version
!   set encoding=utf-8
!   call writefile(0z56494D7375671F, sugfile)
    set runtimepath=./Xtest
    set spelllang=Xtest
!   set spell
!   call assert_fails("let s = spellsuggest('abc')", 'E780:')
    set nospell spelllang&
  
!   " missing suggest timestamp
!   set encoding=utf-8
!   call writefile(0z56494D73756701, sugfile)
    set runtimepath=./Xtest
    set spelllang=Xtest
!   set spell
!   call assert_fails("let s = spellsuggest('abc')", 'E781:')
    set nospell spelllang&
  
!   " incorrect suggest timestamp
!   set encoding=utf-8
!   call writefile(0z56494D7375670100000000000000FF, sugfile)
    set runtimepath=./Xtest
    set spelllang=Xtest
    set spell
+   call assert_fails("let s = spellsuggest('abc')", 'E781:')
    set nospell spelllang&
  
!   " missing suggest wordtree
!   set encoding=utf-8
!   call writefile(0z56494D737567010000000000000044, sugfile)
    set runtimepath=./Xtest
    set spelllang=Xtest
!   set spell
!   call assert_fails("let s = spellsuggest('abc')", 'E782:')
    set nospell spelllang&
  
    let &rtp = save_rtp
    call delete('Xtest', 'rf')
  endfunc
  
+ " Test for using :mkspell to create a spell file from a list of words
+ func Test_wordlist_dic()
+   " duplicate encoding
+   let lines =<< trim [END]
+     # This is an example word list
+ 
+     /encoding=latin1
+     /encoding=latin1
+     example
+   [END]
+   call writefile(lines, 'Xwordlist.dic')
+   let output = execute('mkspell Xwordlist.spl Xwordlist.dic')
+   call assert_match('Duplicate /encoding= line ignored in Xwordlist.dic line 
4: /encoding=latin1', output)
+ 
+   " multiple encoding for a word
+   let lines =<< trim [END]
+     example
+     /encoding=latin1
+     example
+   [END]
+   call writefile(lines, 'Xwordlist.dic')
+   let output = execute('mkspell! Xwordlist.spl Xwordlist.dic')
+   call assert_match('/encoding= line after word ignored in Xwordlist.dic line 
2: /encoding=latin1', output)
+ 
+   " unsupported encoding for a word
+   let lines =<< trim [END]
+     /encoding=Xtest
+     example
+   [END]
+   call writefile(lines, 'Xwordlist.dic')
+   let output = execute('mkspell! Xwordlist.spl Xwordlist.dic')
+   call assert_match('Conversion in Xwordlist.dic not supported: from Xtest to 
utf-8', output)
+ 
+   " duplicate region
+   let lines =<< trim [END]
+     /regions=usca
+     /regions=usca
+     example
+   [END]
+   call writefile(lines, 'Xwordlist.dic')
+   let output = execute('mkspell! Xwordlist.spl Xwordlist.dic')
+   call assert_match('Duplicate /regions= line ignored in Xwordlist.dic line 
2: regions=usca', output)
+ 
+   " maximum regions
+   let lines =<< trim [END]
+     /regions=uscauscauscauscausca
+     example
+   [END]
+   call writefile(lines, 'Xwordlist.dic')
+   let output = execute('mkspell! Xwordlist.spl Xwordlist.dic')
+   call assert_match('Too many regions in Xwordlist.dic line 1: 
uscauscauscauscausca', output)
+ 
+   " unsupported '/' value
+   let lines =<< trim [END]
+     /test=abc
+     example
+   [END]
+   call writefile(lines, 'Xwordlist.dic')
+   let output = execute('mkspell! Xwordlist.spl Xwordlist.dic')
+   call assert_match('/ line ignored in Xwordlist.dic line 1: /test=abc', 
output)
+ 
+   " unsupported flag
+   let lines =<< trim [END]
+     example/+
+   [END]
+   call writefile(lines, 'Xwordlist.dic')
+   let output = execute('mkspell! Xwordlist.spl Xwordlist.dic')
+   call assert_match('Unrecognized flags in Xwordlist.dic line 1: +', output)
+ 
+   " non-ascii word
+   call writefile(["ʀʀ"], 'Xwordlist.dic')
+   let output = execute('mkspell! -ascii Xwordlist.spl Xwordlist.dic')
+   call assert_match('Ignored 1 words with non-ASCII characters', output)
+ 
+   call delete('Xwordlist.spl')
+   call delete('Xwordlist.dic')
+ endfunc
+ 
+ " Test for the :mkspell command
+ func Test_mkspell()
+   call assert_fails('mkspell Xtest_us.spl', 'E751:')
+   call assert_fails('mkspell a b c d e f g h i j k', 'E754:')
+ 
+   call writefile([], 'Xtest.spl')
+   call writefile([], 'Xtest.dic')
+   call assert_fails('mkspell Xtest.spl Xtest.dic', 'E13:')
+   call delete('Xtest.spl')
+   call delete('Xtest.dic')
+ 
+   call mkdir('Xtest.spl')
+   call assert_fails('mkspell! Xtest.spl Xtest.dic', 'E17:')
+   call delete('Xtest.spl', 'rf')
+ 
+   call assert_fails('mkspell en en_US abc_xyz', 'E755:')
+ endfunc
+ 
+ func Test_spell_add_word()
+   set spellfile=
+   call assert_fails('spellgood abc', 'E764:')
+ 
+   set spellfile=Xtest.utf-8.add
+   call assert_fails('2spellgood abc', 'E765:')
+ 
+   edit Xtest.utf-8.add
+   call setline(1, 'sample')
+   call assert_fails('spellgood abc', 'E139:')
+   set spellfile&
+   %bw!
+ endfunc
+ 
  " vim: shiftwidth=2 sts=2 expandtab
*** ../vim-8.2.1492/src/version.c       2020-08-20 15:24:56.482101905 +0200
--- src/version.c       2020-08-20 15:41:22.181093658 +0200
***************
*** 756,757 ****
--- 756,759 ----
  {   /* Add new patch number below this line */
+ /**/
+     1493,
  /**/

-- 
hundred-and-one symptoms of being an internet addict:
246. You use up your free 1 Gbyte in two days.

 /// Bram Moolenaar -- [email protected] -- http://www.Moolenaar.net   \\\
///        sponsor Vim, vote for features -- http://www.Vim.org/sponsor/ \\\
\\\  an exciting new programming language -- http://www.Zimbu.org        ///
 \\\            help me help AIDS victims -- http://ICCF-Holland.org    ///

-- 
-- 
You received this message from the "vim_dev" maillist.
Do not top-post! Type your reply below the text you are replying to.
For more information, visit http://www.vim.org/maillist.php

--- 
You received this message because you are subscribed to the Google Groups 
"vim_dev" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to [email protected].
To view this discussion on the web visit 
https://groups.google.com/d/msgid/vim_dev/202008201342.07KDgTZA205344%40masaka.moolenaar.net.

Raspunde prin e-mail lui