diff options
author | James Ahlborn <jtahlborn@yahoo.com> | 2018-06-26 02:39:20 +0000 |
---|---|---|
committer | James Ahlborn <jtahlborn@yahoo.com> | 2018-06-26 02:39:20 +0000 |
commit | f495fcc761bcb275215f0d7d81b0135d8db56e2a (patch) | |
tree | 4500eb2ab3e081729910f18a047eefb7a47aa370 /src/test/java/com/healthmarketscience/jackcess/impl | |
parent | 2faf773bb91bccafcddd67c914bd5b38f5e99162 (diff) | |
download | jackcess-f495fcc761bcb275215f0d7d81b0135d8db56e2a.tar.gz jackcess-f495fcc761bcb275215f0d7d81b0135d8db56e2a.zip |
add some tests for functions; fix said functions
git-svn-id: https://svn.code.sf.net/p/jackcess/code/jackcess/branches/exprs@1166 f203690c-595d-4dc9-a70b-905162fa7fd2
Diffstat (limited to 'src/test/java/com/healthmarketscience/jackcess/impl')
-rw-r--r-- | src/test/java/com/healthmarketscience/jackcess/impl/expr/DefaultFunctionsTest.java | 26 |
1 files changed, 25 insertions, 1 deletions
diff --git a/src/test/java/com/healthmarketscience/jackcess/impl/expr/DefaultFunctionsTest.java b/src/test/java/com/healthmarketscience/jackcess/impl/expr/DefaultFunctionsTest.java index 981c4d3..0b02888 100644 --- a/src/test/java/com/healthmarketscience/jackcess/impl/expr/DefaultFunctionsTest.java +++ b/src/test/java/com/healthmarketscience/jackcess/impl/expr/DefaultFunctionsTest.java @@ -76,7 +76,31 @@ public class DefaultFunctionsTest extends TestCase assertEquals("9786", eval("=CStr(9786)")); assertEquals("-42", eval("=CStr(-42)")); - // FIXME, instr, instrrev + assertEquals(2, eval("=InStr('AFOOBAR', 'FOO')")); + assertEquals(2, eval("=InStr('AFOOBAR', 'foo')")); + assertEquals(2, eval("=InStr(1, 'AFOOBAR', 'foo')")); + assertEquals(0, eval("=InStr(1, 'AFOOBAR', 'foo', 0)")); + assertEquals(2, eval("=InStr(1, 'AFOOBAR', 'foo', 1)")); + assertEquals(2, eval("=InStr(1, 'AFOOBAR', 'FOO', 0)")); + assertEquals(2, eval("=InStr(2, 'AFOOBAR', 'FOO')")); + assertEquals(0, eval("=InStr(3, 'AFOOBAR', 'FOO')")); + assertEquals(0, eval("=InStr(17, 'AFOOBAR', 'FOO')")); + assertEquals(2, eval("=InStr(1, 'AFOOBARFOOBAR', 'FOO')")); + assertEquals(8, eval("=InStr(3, 'AFOOBARFOOBAR', 'FOO')")); + assertNull(eval("=InStr(3, Null, 'FOO')")); + + assertEquals(2, eval("=InStrRev('AFOOBAR', 'FOO')")); + assertEquals(2, eval("=InStrRev('AFOOBAR', 'foo')")); + assertEquals(2, eval("=InStrRev('AFOOBAR', 'foo', -1)")); + assertEquals(0, eval("=InStrRev('AFOOBAR', 'foo', -1, 0)")); + assertEquals(2, eval("=InStrRev('AFOOBAR', 'foo', -1, 1)")); + assertEquals(2, eval("=InStrRev('AFOOBAR', 'FOO', -1, 0)")); + assertEquals(2, eval("=InStrRev('AFOOBAR', 'FOO', 4)")); + assertEquals(0, eval("=InStrRev('AFOOBAR', 'FOO', 3)")); + assertEquals(2, eval("=InStrRev('AFOOBAR', 'FOO', 17)")); + assertEquals(2, eval("=InStrRev('AFOOBARFOOBAR', 'FOO', 9)")); + assertEquals(8, eval("=InStrRev('AFOOBARFOOBAR', 'FOO', 10)")); + assertNull(eval("=InStrRev(Null, 'FOO', 3)")); assertEquals("FOOO", eval("=UCase(\"fOoO\")")); assertEquals("fooo", eval("=LCase(\"fOoO\")")); |