initial commits
							parent
							
								
									cd585814c3
								
							
						
					
					
						commit
						181c88bdfc
					
				| 
						 | 
					@ -0,0 +1,27 @@
 | 
				
			||||||
 | 
					package escaped
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import (
 | 
				
			||||||
 | 
						"sourcecode.social/reiver/go-rfc2396/hex"
 | 
				
			||||||
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func Bytes(p []byte) (result []byte, rest []byte, ok bool) {
 | 
				
			||||||
 | 
						length := len(p)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if length < 3 {
 | 
				
			||||||
 | 
							return nil, p, false
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						p0, p1, p2 := p[0], p[1], p[2]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if '%' != p0 {
 | 
				
			||||||
 | 
							return nil, p, false
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						if !hex.ByteIs(p1) {
 | 
				
			||||||
 | 
							return nil, p, false
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						if !hex.ByteIs(p2) {
 | 
				
			||||||
 | 
							return nil, p, false
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						return p[:3], p[3:], true
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,225 @@
 | 
				
			||||||
 | 
					package escaped_test
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import (
 | 
				
			||||||
 | 
						"testing"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						"bytes"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						"sourcecode.social/reiver/go-rfc2396/escaped"
 | 
				
			||||||
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func TestBytes(t *testing.T) {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						tests := []struct{
 | 
				
			||||||
 | 
							Value []byte
 | 
				
			||||||
 | 
							ExpectedResult []byte
 | 
				
			||||||
 | 
							ExpectedRest []byte
 | 
				
			||||||
 | 
							ExpectedOK bool
 | 
				
			||||||
 | 
						}{
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								Value: nil,
 | 
				
			||||||
 | 
								ExpectedResult: nil,
 | 
				
			||||||
 | 
								ExpectedRest: nil,
 | 
				
			||||||
 | 
								ExpectedOK: false,
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								Value: []byte(nil),
 | 
				
			||||||
 | 
								ExpectedResult: nil,
 | 
				
			||||||
 | 
								ExpectedRest: nil,
 | 
				
			||||||
 | 
								ExpectedOK: false,
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								Value: []byte{},
 | 
				
			||||||
 | 
								ExpectedResult: nil,
 | 
				
			||||||
 | 
								ExpectedRest: nil,
 | 
				
			||||||
 | 
								ExpectedOK: false,
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								Value: []byte(""),
 | 
				
			||||||
 | 
								ExpectedResult: nil,
 | 
				
			||||||
 | 
								ExpectedRest: nil,
 | 
				
			||||||
 | 
								ExpectedOK: false,
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								Value:          []byte{'%','f','0',  '%','9','f',  '%','9','9',   '%','8','b'}, // == '🙂'
 | 
				
			||||||
 | 
								ExpectedResult: []byte{'%','f','0'},
 | 
				
			||||||
 | 
								ExpectedRest:                 []byte{'%','9','f',  '%','9','9',   '%','8','b'},
 | 
				
			||||||
 | 
								ExpectedOK: true,
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								Value:          []byte{'%','1','b',  '[','9','3',';','4','1','m',   'H','e','l','l','o',' ','w','o','r','l','d','!',   '%','1','b',   '[','0','m'},
 | 
				
			||||||
 | 
								ExpectedResult: []byte{'%','1','b'},
 | 
				
			||||||
 | 
								ExpectedRest:                 []byte{'[','9','3',';','4','1','m',   'H','e','l','l','o',' ','w','o','r','l','d','!',   '%','1','b',   '[','0','m'},
 | 
				
			||||||
 | 
								ExpectedOK: true,
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								Value:        []byte{'%','%','%','%'},
 | 
				
			||||||
 | 
								ExpectedResult: nil,
 | 
				
			||||||
 | 
								ExpectedRest: []byte{'%','%','%','%'},
 | 
				
			||||||
 | 
								ExpectedOK: false,
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								Value:        []byte{'%','%','%'},
 | 
				
			||||||
 | 
								ExpectedResult: nil,
 | 
				
			||||||
 | 
								ExpectedRest: []byte{'%','%','%'},
 | 
				
			||||||
 | 
								ExpectedOK: false,
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								Value:        []byte{'%','%'},
 | 
				
			||||||
 | 
								ExpectedResult: nil,
 | 
				
			||||||
 | 
								ExpectedRest: []byte{'%','%'},
 | 
				
			||||||
 | 
								ExpectedOK: false,
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								Value:        []byte{'%'},
 | 
				
			||||||
 | 
								ExpectedResult: nil,
 | 
				
			||||||
 | 
								ExpectedRest: []byte{'%'},
 | 
				
			||||||
 | 
								ExpectedOK: false,
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						for _, b := range []byte{'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'} {
 | 
				
			||||||
 | 
							test := struct{
 | 
				
			||||||
 | 
								Value []byte
 | 
				
			||||||
 | 
								ExpectedResult []byte
 | 
				
			||||||
 | 
								ExpectedRest []byte
 | 
				
			||||||
 | 
								ExpectedOK bool
 | 
				
			||||||
 | 
							}{
 | 
				
			||||||
 | 
								Value:        []byte{'%', b},
 | 
				
			||||||
 | 
								ExpectedResult:  nil,
 | 
				
			||||||
 | 
								ExpectedRest: []byte{'%', b},
 | 
				
			||||||
 | 
								ExpectedOK: false,
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							tests = append(tests, test)
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						for _, b1 := range []byte{'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'} {
 | 
				
			||||||
 | 
							for _, b2 := range []byte{'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'} {
 | 
				
			||||||
 | 
								test := struct{
 | 
				
			||||||
 | 
									Value []byte
 | 
				
			||||||
 | 
									ExpectedResult []byte
 | 
				
			||||||
 | 
									ExpectedRest []byte
 | 
				
			||||||
 | 
									ExpectedOK bool
 | 
				
			||||||
 | 
								}{
 | 
				
			||||||
 | 
									Value:          []byte{'%', b1, b2},
 | 
				
			||||||
 | 
									ExpectedResult: []byte{'%', b1, b2},
 | 
				
			||||||
 | 
									ExpectedRest:  nil,
 | 
				
			||||||
 | 
									ExpectedOK: true,
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								tests = append(tests, test)
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						for _, b1 := range []byte{'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'} {
 | 
				
			||||||
 | 
							for _, b2 := range []byte{'0','1','2','3','4','5','6','7','8','9','a','b','c','d','e','f'} {
 | 
				
			||||||
 | 
								test := struct{
 | 
				
			||||||
 | 
									Value []byte
 | 
				
			||||||
 | 
									ExpectedResult []byte
 | 
				
			||||||
 | 
									ExpectedRest []byte
 | 
				
			||||||
 | 
									ExpectedOK bool
 | 
				
			||||||
 | 
								}{
 | 
				
			||||||
 | 
									Value:          []byte{'%', b1, b2},
 | 
				
			||||||
 | 
									ExpectedResult: []byte{'%', b1, b2},
 | 
				
			||||||
 | 
									ExpectedRest:  nil,
 | 
				
			||||||
 | 
									ExpectedOK: true,
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								tests = append(tests, test)
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						for _, b1 := range []byte{'0','1','2','3','4','5','6','7','8','9','a','b','c','d','e','f'} {
 | 
				
			||||||
 | 
							for _, b2 := range []byte{'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'} {
 | 
				
			||||||
 | 
								test := struct{
 | 
				
			||||||
 | 
									Value []byte
 | 
				
			||||||
 | 
									ExpectedResult []byte
 | 
				
			||||||
 | 
									ExpectedRest []byte
 | 
				
			||||||
 | 
									ExpectedOK bool
 | 
				
			||||||
 | 
								}{
 | 
				
			||||||
 | 
									Value:          []byte{'%', b1, b2},
 | 
				
			||||||
 | 
									ExpectedResult: []byte{'%', b1, b2},
 | 
				
			||||||
 | 
									ExpectedRest:  nil,
 | 
				
			||||||
 | 
									ExpectedOK: true,
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								tests = append(tests, test)
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						for _, b1 := range []byte{'0','1','2','3','4','5','6','7','8','9','a','b','c','d','e','f'} {
 | 
				
			||||||
 | 
							for _, b2 := range []byte{'0','1','2','3','4','5','6','7','8','9','a','b','c','d','e','f'} {
 | 
				
			||||||
 | 
								test := struct{
 | 
				
			||||||
 | 
									Value []byte
 | 
				
			||||||
 | 
									ExpectedResult []byte
 | 
				
			||||||
 | 
									ExpectedRest []byte
 | 
				
			||||||
 | 
									ExpectedOK bool
 | 
				
			||||||
 | 
								}{
 | 
				
			||||||
 | 
									Value:          []byte{'%', b1, b2},
 | 
				
			||||||
 | 
									ExpectedResult: []byte{'%', b1, b2},
 | 
				
			||||||
 | 
									ExpectedRest:  nil,
 | 
				
			||||||
 | 
									ExpectedOK: true,
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								tests = append(tests, test)
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						for testNumber, test := range tests {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							actualResult, actualRest, actualOK := escaped.Bytes(test.Value)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								expected := test.ExpectedOK
 | 
				
			||||||
 | 
								actual   := actualOK
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								if expected != actual {
 | 
				
			||||||
 | 
									t.Errorf("For test #%d, the actual ok-result is not what was expected.", testNumber)
 | 
				
			||||||
 | 
									t.Logf("EXPECTED: %t", expected)
 | 
				
			||||||
 | 
									t.Logf("ACTUAL:   %t", actual)
 | 
				
			||||||
 | 
									t.Logf("VALUE: %q (%#v)", test.Value, test.Value)
 | 
				
			||||||
 | 
									continue
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								expected := test.ExpectedResult
 | 
				
			||||||
 | 
								actual   := actualResult
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								if !bytes.Equal(expected,actual) {
 | 
				
			||||||
 | 
									t.Errorf("For test #%d, the actual result is not what was expected.", testNumber)
 | 
				
			||||||
 | 
									t.Logf("EXPECTED: %q (%#v)", expected, expected)
 | 
				
			||||||
 | 
									t.Logf("ACTUAL:   %q (%#v)", actual, actual)
 | 
				
			||||||
 | 
									t.Logf("VALUE: %q (%#v)", test.Value, test.Value)
 | 
				
			||||||
 | 
									t.Logf("ACTUAL-REST:   %q (%#v)", actualRest, actualRest)
 | 
				
			||||||
 | 
									continue
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								expected := test.ExpectedRest
 | 
				
			||||||
 | 
								actual   := actualRest
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								if !bytes.Equal(expected,actual) {
 | 
				
			||||||
 | 
									t.Errorf("For test #%d, the actual rest-result is not what was expected.", testNumber)
 | 
				
			||||||
 | 
									t.Logf("EXPECTED: %q (%#v)", expected, expected)
 | 
				
			||||||
 | 
									t.Logf("ACTUAL:   %q (%#v)", actual, actual)
 | 
				
			||||||
 | 
									t.Logf("VALUE: %q (%#v)", test.Value, test.Value)
 | 
				
			||||||
 | 
									continue
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
		Loading…
	
		Reference in New Issue