Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-cw
Commits
e21cb8fb
Commit
e21cb8fb
authored
Oct 19, 2010
by
Juan Lang
Committed by
Alexandre Julliard
Oct 20, 2010
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
crypt32/tests: Test more Unicode encoded string to string conversions.
parent
41416252
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
70 additions
and
19 deletions
+70
-19
str.c
dlls/crypt32/tests/str.c
+70
-19
No files found.
dlls/crypt32/tests/str.c
View file @
e21cb8fb
...
@@ -468,18 +468,29 @@ static void test_CertNameToStrA(void)
...
@@ -468,18 +468,29 @@ static void test_CertNameToStrA(void)
}
}
static
void
test_NameToStrConversionW
(
PCERT_NAME_BLOB
pName
,
DWORD
dwStrType
,
static
void
test_NameToStrConversionW
(
PCERT_NAME_BLOB
pName
,
DWORD
dwStrType
,
LPCWSTR
expected
)
LPCWSTR
expected
,
BOOL
todo
)
{
{
WCHAR
buffer
[
2000
]
=
{
0
};
WCHAR
buffer
[
2000
]
=
{
0
};
DWORD
i
;
DWORD
i
;
i
=
pCertNameToStrW
(
X509_ASN_ENCODING
,
pName
,
dwStrType
,
NULL
,
0
);
i
=
pCertNameToStrW
(
X509_ASN_ENCODING
,
pName
,
dwStrType
,
NULL
,
0
);
if
(
todo
)
todo_wine
ok
(
i
==
lstrlenW
(
expected
)
+
1
,
"Expected %d chars, got %d
\n
"
,
lstrlenW
(
expected
)
+
1
,
i
);
else
ok
(
i
==
lstrlenW
(
expected
)
+
1
,
"Expected %d chars, got %d
\n
"
,
ok
(
i
==
lstrlenW
(
expected
)
+
1
,
"Expected %d chars, got %d
\n
"
,
lstrlenW
(
expected
)
+
1
,
i
);
lstrlenW
(
expected
)
+
1
,
i
);
i
=
pCertNameToStrW
(
X509_ASN_ENCODING
,
pName
,
dwStrType
,
buffer
,
i
=
pCertNameToStrW
(
X509_ASN_ENCODING
,
pName
,
dwStrType
,
buffer
,
sizeof
(
buffer
)
/
sizeof
(
buffer
[
0
]));
sizeof
(
buffer
)
/
sizeof
(
buffer
[
0
]));
if
(
todo
)
todo_wine
ok
(
i
==
lstrlenW
(
expected
)
+
1
,
"Expected %d chars, got %d
\n
"
,
lstrlenW
(
expected
)
+
1
,
i
);
else
ok
(
i
==
lstrlenW
(
expected
)
+
1
,
"Expected %d chars, got %d
\n
"
,
ok
(
i
==
lstrlenW
(
expected
)
+
1
,
"Expected %d chars, got %d
\n
"
,
lstrlenW
(
expected
)
+
1
,
i
);
lstrlenW
(
expected
)
+
1
,
i
);
if
(
todo
)
todo_wine
ok
(
!
lstrcmpW
(
buffer
,
expected
),
"Unexpected value
\n
"
);
else
ok
(
!
lstrcmpW
(
buffer
,
expected
),
"Unexpected value
\n
"
);
ok
(
!
lstrcmpW
(
buffer
,
expected
),
"Unexpected value
\n
"
);
#ifdef DUMP_STRINGS
#ifdef DUMP_STRINGS
trace
(
"Expected %s, got %s
\n
"
,
trace
(
"Expected %s, got %s
\n
"
,
...
@@ -487,9 +498,22 @@ static void test_NameToStrConversionW(PCERT_NAME_BLOB pName, DWORD dwStrType,
...
@@ -487,9 +498,22 @@ static void test_NameToStrConversionW(PCERT_NAME_BLOB pName, DWORD dwStrType,
#endif
#endif
}
}
static
const
WCHAR
simpleCN_W
[]
=
{
'C'
,
'N'
,
'='
,
'1'
,
0
};
static
const
WCHAR
singledQuotedCN_W
[]
=
{
'C'
,
'N'
,
'='
,
'\''
,
'1'
,
'\''
,
0
};
static
const
WCHAR
spacedCN_W
[]
=
{
'C'
,
'N'
,
'='
,
'"'
,
' '
,
'1'
,
' '
,
'"'
,
0
};
static
const
WCHAR
quotedCN_W
[]
=
{
'C'
,
'N'
,
'='
,
'"'
,
'"'
,
'"'
,
'1'
,
'"'
,
'"'
,
'"'
,
0
};
static
const
WCHAR
multipleAttrCN_W
[]
=
{
'C'
,
'N'
,
'='
,
'"'
,
'1'
,
'+'
,
'2'
,
'"'
,
0
};
static
const
WCHAR
commaCN_W
[]
=
{
'C'
,
'N'
,
'='
,
'"'
,
'a'
,
','
,
'b'
,
'"'
,
0
};
static
const
WCHAR
equalCN_W
[]
=
{
'C'
,
'N'
,
'='
,
'"'
,
'a'
,
'='
,
'b'
,
'"'
,
0
};
static
const
WCHAR
lessThanCN_W
[]
=
{
'C'
,
'N'
,
'='
,
'"'
,
'<'
,
'"'
,
0
};
static
const
WCHAR
greaterThanCN_W
[]
=
{
'C'
,
'N'
,
'='
,
'"'
,
'>'
,
'"'
,
0
};
static
const
WCHAR
hashCN_W
[]
=
{
'C'
,
'N'
,
'='
,
'"'
,
'#'
,
'"'
,
0
};
static
const
WCHAR
semiCN_W
[]
=
{
'C'
,
'N'
,
'='
,
'"'
,
';'
,
'"'
,
0
};
static
void
test_CertNameToStrW
(
void
)
static
void
test_CertNameToStrW
(
void
)
{
{
PCCERT_CONTEXT
context
;
PCCERT_CONTEXT
context
;
CERT_NAME_BLOB
blob
;
if
(
!
pCertNameToStrW
)
if
(
!
pCertNameToStrW
)
{
{
...
@@ -522,26 +546,64 @@ static void test_CertNameToStrW(void)
...
@@ -522,26 +546,64 @@ static void test_CertNameToStrW(void)
ret
,
GetLastError
());
ret
,
GetLastError
());
test_NameToStrConversionW
(
&
context
->
pCertInfo
->
Issuer
,
test_NameToStrConversionW
(
&
context
->
pCertInfo
->
Issuer
,
CERT_SIMPLE_NAME_STR
,
issuerStrW
);
CERT_SIMPLE_NAME_STR
,
issuerStrW
,
FALSE
);
test_NameToStrConversionW
(
&
context
->
pCertInfo
->
Issuer
,
test_NameToStrConversionW
(
&
context
->
pCertInfo
->
Issuer
,
CERT_SIMPLE_NAME_STR
|
CERT_NAME_STR_SEMICOLON_FLAG
,
CERT_SIMPLE_NAME_STR
|
CERT_NAME_STR_SEMICOLON_FLAG
,
issuerStrSemicolonW
);
issuerStrSemicolonW
,
FALSE
);
test_NameToStrConversionW
(
&
context
->
pCertInfo
->
Issuer
,
test_NameToStrConversionW
(
&
context
->
pCertInfo
->
Issuer
,
CERT_SIMPLE_NAME_STR
|
CERT_NAME_STR_CRLF_FLAG
,
CERT_SIMPLE_NAME_STR
|
CERT_NAME_STR_CRLF_FLAG
,
issuerStrCRLFW
);
issuerStrCRLFW
,
FALSE
);
test_NameToStrConversionW
(
&
context
->
pCertInfo
->
Subject
,
test_NameToStrConversionW
(
&
context
->
pCertInfo
->
Subject
,
CERT_OID_NAME_STR
,
subjectStrW
);
CERT_OID_NAME_STR
,
subjectStrW
,
FALSE
);
test_NameToStrConversionW
(
&
context
->
pCertInfo
->
Subject
,
test_NameToStrConversionW
(
&
context
->
pCertInfo
->
Subject
,
CERT_OID_NAME_STR
|
CERT_NAME_STR_SEMICOLON_FLAG
,
CERT_OID_NAME_STR
|
CERT_NAME_STR_SEMICOLON_FLAG
,
subjectStrSemicolonW
);
subjectStrSemicolonW
,
FALSE
);
test_NameToStrConversionW
(
&
context
->
pCertInfo
->
Subject
,
test_NameToStrConversionW
(
&
context
->
pCertInfo
->
Subject
,
CERT_OID_NAME_STR
|
CERT_NAME_STR_CRLF_FLAG
,
CERT_OID_NAME_STR
|
CERT_NAME_STR_CRLF_FLAG
,
subjectStrCRLFW
);
subjectStrCRLFW
,
FALSE
);
test_NameToStrConversionW
(
&
context
->
pCertInfo
->
Subject
,
test_NameToStrConversionW
(
&
context
->
pCertInfo
->
Subject
,
CERT_X500_NAME_STR
|
CERT_NAME_STR_SEMICOLON_FLAG
|
CERT_NAME_STR_REVERSE_FLAG
,
x500SubjectStrSemicolonReverseW
);
CERT_X500_NAME_STR
|
CERT_NAME_STR_SEMICOLON_FLAG
|
CERT_NAME_STR_REVERSE_FLAG
,
x500SubjectStrSemicolonReverseW
,
FALSE
);
CertFreeCertificateContext
(
context
);
CertFreeCertificateContext
(
context
);
}
}
blob
.
pbData
=
encodedSimpleCN
;
blob
.
cbData
=
sizeof
(
encodedSimpleCN
);
test_NameToStrConversionW
(
&
blob
,
CERT_X500_NAME_STR
,
simpleCN_W
,
FALSE
);
blob
.
pbData
=
encodedSingleQuotedCN
;
blob
.
cbData
=
sizeof
(
encodedSingleQuotedCN
);
test_NameToStrConversionW
(
&
blob
,
CERT_X500_NAME_STR
,
singledQuotedCN_W
,
FALSE
);
blob
.
pbData
=
encodedSpacedCN
;
blob
.
cbData
=
sizeof
(
encodedSpacedCN
);
test_NameToStrConversionW
(
&
blob
,
CERT_X500_NAME_STR
,
spacedCN_W
,
FALSE
);
blob
.
pbData
=
encodedQuotedCN
;
blob
.
cbData
=
sizeof
(
encodedQuotedCN
);
test_NameToStrConversionW
(
&
blob
,
CERT_X500_NAME_STR
,
quotedCN_W
,
TRUE
);
blob
.
pbData
=
encodedMultipleAttrCN
;
blob
.
cbData
=
sizeof
(
encodedMultipleAttrCN
);
test_NameToStrConversionW
(
&
blob
,
CERT_X500_NAME_STR
,
multipleAttrCN_W
,
FALSE
);
blob
.
pbData
=
encodedCommaCN
;
blob
.
cbData
=
sizeof
(
encodedCommaCN
);
test_NameToStrConversionW
(
&
blob
,
CERT_X500_NAME_STR
,
commaCN_W
,
FALSE
);
blob
.
pbData
=
encodedEqualCN
;
blob
.
cbData
=
sizeof
(
encodedEqualCN
);
test_NameToStrConversionW
(
&
blob
,
CERT_X500_NAME_STR
,
equalCN_W
,
FALSE
);
blob
.
pbData
=
encodedLessThanCN
;
blob
.
cbData
=
sizeof
(
encodedLessThanCN
);
test_NameToStrConversionW
(
&
blob
,
CERT_X500_NAME_STR
,
lessThanCN_W
,
TRUE
);
blob
.
pbData
=
encodedGreaterThanCN
;
blob
.
cbData
=
sizeof
(
encodedGreaterThanCN
);
test_NameToStrConversionW
(
&
blob
,
CERT_X500_NAME_STR
,
greaterThanCN_W
,
TRUE
);
blob
.
pbData
=
encodedHashCN
;
blob
.
cbData
=
sizeof
(
encodedHashCN
);
test_NameToStrConversionW
(
&
blob
,
CERT_X500_NAME_STR
,
hashCN_W
,
TRUE
);
blob
.
pbData
=
encodedSemiCN
;
blob
.
cbData
=
sizeof
(
encodedSemiCN
);
test_NameToStrConversionW
(
&
blob
,
CERT_X500_NAME_STR
,
semiCN_W
,
TRUE
);
}
}
struct
StrToNameA
struct
StrToNameA
...
@@ -627,22 +689,11 @@ struct StrToNameW
...
@@ -627,22 +689,11 @@ struct StrToNameW
};
};
static
const
WCHAR
badlyQuotedCN_W
[]
=
{
'C'
,
'N'
,
'='
,
'"'
,
'"'
,
'1'
,
'"'
,
'"'
,
0
};
static
const
WCHAR
badlyQuotedCN_W
[]
=
{
'C'
,
'N'
,
'='
,
'"'
,
'"'
,
'1'
,
'"'
,
'"'
,
0
};
static
const
WCHAR
simpleCN_W
[]
=
{
'C'
,
'N'
,
'='
,
'1'
,
0
};
static
const
WCHAR
simpleCN2_W
[]
=
{
'C'
,
'N'
,
'='
,
'"'
,
'1'
,
'"'
,
0
};
static
const
WCHAR
simpleCN2_W
[]
=
{
'C'
,
'N'
,
'='
,
'"'
,
'1'
,
'"'
,
0
};
static
const
WCHAR
simpleCN3_W
[]
=
{
'C'
,
'N'
,
' '
,
'='
,
' '
,
'"'
,
'1'
,
'"'
,
0
};
static
const
WCHAR
simpleCN3_W
[]
=
{
'C'
,
'N'
,
' '
,
'='
,
' '
,
'"'
,
'1'
,
'"'
,
0
};
static
const
WCHAR
singledQuotedCN_W
[]
=
{
'C'
,
'N'
,
'='
,
'\''
,
'1'
,
'\''
,
0
};
static
const
WCHAR
spacedCN_W
[]
=
{
'C'
,
'N'
,
'='
,
'"'
,
' '
,
'1'
,
' '
,
'"'
,
0
};
static
const
WCHAR
quotedCN_W
[]
=
{
'C'
,
'N'
,
'='
,
'"'
,
'"'
,
'"'
,
'1'
,
'"'
,
'"'
,
'"'
,
0
};
static
const
WCHAR
multipleAttrCN_W
[]
=
{
'C'
,
'N'
,
'='
,
'"'
,
'1'
,
'+'
,
'2'
,
'"'
,
0
};
static
const
WCHAR
japaneseCN_W
[]
=
{
'C'
,
'N'
,
'='
,
0x226f
,
0x575b
,
0
};
static
const
WCHAR
japaneseCN_W
[]
=
{
'C'
,
'N'
,
'='
,
0x226f
,
0x575b
,
0
};
static
const
BYTE
encodedJapaneseCN
[]
=
{
0x30
,
0x0f
,
0x31
,
0x0d
,
0x30
,
0x0b
,
0x06
,
static
const
BYTE
encodedJapaneseCN
[]
=
{
0x30
,
0x0f
,
0x31
,
0x0d
,
0x30
,
0x0b
,
0x06
,
0x03
,
0x55
,
0x04
,
0x03
,
0x1e
,
0x04
,
0x22
,
0x6f
,
0x57
,
0x5b
};
0x03
,
0x55
,
0x04
,
0x03
,
0x1e
,
0x04
,
0x22
,
0x6f
,
0x57
,
0x5b
};
static
const
WCHAR
commaCN_W
[]
=
{
'C'
,
'N'
,
'='
,
'"'
,
'a'
,
','
,
'b'
,
'"'
,
0
};
static
const
WCHAR
equalCN_W
[]
=
{
'C'
,
'N'
,
'='
,
'"'
,
'a'
,
'='
,
'b'
,
'"'
,
0
};
static
const
WCHAR
lessThanCN_W
[]
=
{
'C'
,
'N'
,
'='
,
'"'
,
'<'
,
'"'
,
0
};
static
const
WCHAR
greaterThanCN_W
[]
=
{
'C'
,
'N'
,
'='
,
'"'
,
'>'
,
'"'
,
0
};
static
const
WCHAR
hashCN_W
[]
=
{
'C'
,
'N'
,
'='
,
'"'
,
'#'
,
'"'
,
0
};
static
const
WCHAR
semiCN_W
[]
=
{
'C'
,
'N'
,
'='
,
'"'
,
';'
,
'"'
,
0
};
static
const
struct
StrToNameW
namesW
[]
=
{
static
const
struct
StrToNameW
namesW
[]
=
{
{
simpleCN_W
,
sizeof
(
encodedSimpleCN
),
encodedSimpleCN
},
{
simpleCN_W
,
sizeof
(
encodedSimpleCN
),
encodedSimpleCN
},
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment