#!/usr/bin/pugs
use v6;
use Test;
plan 23;
# Simple - with just a single char
is(index("Hello World", "H"), 0, "One char, at beginning");
is(index("Hello World", "l"), 2, "One char, in the middle");
is(index("Hello World", "d"), 10, "One char, in the end");
is(index("Hello World", "x"), -1, "One char, no match");
is(index("Hello World", "l", 0), 2, "One char, find first match, pos = 0");
is(index("Hello World", "l", 2), 2, "- 1. match again, pos @ match");
is(index("Hello World", "l", 3), 3, "- 2. match");
is(index("Hello World", "l", 4), 9, "- 3. match");
is(index("Hello World", "l", 10), -1, "- no more matches");
# Simple - with a string
is(index("Hello World", "Hello"), 0, "Substr, at beginning");
is(index("Hello World", "o W"), 4, "Substr, in the middle");
is(index("Hello World", "World"), 6, "Substr, at the end");
is(index("Hello World", "low"), -1, "Substr, no match");
is(index("Hello World", "Hello World"), 0, "Substr eq Str");
# Empty strings
is(index("Hello World", ""), 0, "Substr is empty");
is(index("", ""), 0, "Both strings are empty");
is(index("", "Hello"), -1, "Only main-string is empty");
is(index("Hello", "", 3), 3, "Substr is empty, pos within str");
is(index("Hello", "", 5), 5, "Substr is empty, pos at end of str");
is(index("Hello", "", 999), 5, "Substr is empty, pos > length of str");
# More difficult strings
is(index("ababcabcd", "abcd"), 5, "Start-of-substr matches several times");
is(index("uuúuúuùù", "úuù"), 4, "Accented chars");
is(index("Ümlaut", "Ü"), 0, "Umlaut");