MSI: add format record tests

Mike McCormack mike at codeweavers.com
Fri May 27 12:01:16 CDT 2005


ChangeLog:
<aric at codeweavers.com>
<mike at codeweavers.com>
* add format record tests
-------------- next part --------------
? dlls/msi/tests/format.c
Index: dlls/msi/tests/.cvsignore
===================================================================
RCS file: /home/wine/wine/dlls/msi/tests/.cvsignore,v
retrieving revision 1.3
diff -u -p -r1.3 .cvsignore
--- dlls/msi/tests/.cvsignore	19 Mar 2005 17:08:34 -0000	1.3
+++ dlls/msi/tests/.cvsignore	27 May 2005 17:02:38 -0000
@@ -1,5 +1,6 @@
 Makefile
 db.ok
+format.ok
 record.ok
 suminfo.ok
 testlist.c
Index: dlls/msi/tests/Makefile.in
===================================================================
RCS file: /home/wine/wine/dlls/msi/tests/Makefile.in,v
retrieving revision 1.3
diff -u -p -r1.3 Makefile.in
--- dlls/msi/tests/Makefile.in	19 Mar 2005 17:08:34 -0000	1.3
+++ dlls/msi/tests/Makefile.in	27 May 2005 17:02:38 -0000
@@ -7,6 +7,7 @@ IMPORTS   = msi kernel32
 
 CTESTS = \
 	db.c \
+	format.c \
 	record.c \
 	suminfo.c
 
Index: dlls/msi/tests/db.c
===================================================================
RCS file: /home/wine/wine/dlls/msi/tests/db.c,v
retrieving revision 1.10
diff -u -p -r1.10 db.c
--- dlls/msi/tests/db.c	19 May 2005 11:15:37 -0000	1.10
+++ dlls/msi/tests/db.c	27 May 2005 17:02:39 -0000
@@ -25,82 +25,6 @@
 
 #include "wine/test.h"
 
-MSIHANDLE helper_createpackage()
-{
-    MSIHANDLE hdb = 0;
-    CHAR szName[] = "C:\\mytest.msi";
-    UINT res;
-    CHAR szPackage[10];
-    MSIHANDLE hPackage;
-    MSIHANDLE suminfo;
-
-    DeleteFile(szName);
-
-    /* create an empty database */
-    res = MsiOpenDatabase(szName, MSIDBOPEN_CREATE, &hdb );
-    ok( res == ERROR_SUCCESS , "Failed to create database\n" );
-
-    res = MsiDatabaseCommit( hdb );
-    ok( res == ERROR_SUCCESS , "Failed to commit database\n" );
-
-    /* build summmary info */
-    res = MsiGetSummaryInformation(hdb, NULL, 7, &suminfo);
-    ok( res == ERROR_SUCCESS , "Failed to open summaryinfo\n" );
-
-    res = MsiSummaryInfoSetProperty(suminfo,2, VT_LPSTR, 0,NULL,
-                        "Installation Database");
-    ok( res == ERROR_SUCCESS , "Failed to set summary info\n" );
-
-    res = MsiSummaryInfoSetProperty(suminfo,3, VT_LPSTR, 0,NULL,
-                        "Installation Database");
-    ok( res == ERROR_SUCCESS , "Failed to set summary info\n" );
-
-    res = MsiSummaryInfoSetProperty(suminfo,4, VT_LPSTR, 0,NULL,
-                        "Wine Hackers");
-    ok( res == ERROR_SUCCESS , "Failed to set summary info\n" );
-
-    res = MsiSummaryInfoSetProperty(suminfo,7, VT_LPSTR, 0,NULL,
-                    ";1033");
-    ok( res == ERROR_SUCCESS , "Failed to set summary info\n" );
-
-    res = MsiSummaryInfoSetProperty(suminfo,9, VT_LPSTR, 0,NULL,
-                    "{913B8D18-FBB6-4CAC-A239-C74C11E3FA74}");
-    ok( res == ERROR_SUCCESS , "Failed to set summary info\n" );
-
-    res = MsiSummaryInfoSetProperty(suminfo, 14, VT_I4, 100, NULL, NULL);
-    ok( res == ERROR_SUCCESS , "Failed to set summary info\n" );
-
-    res = MsiSummaryInfoSetProperty(suminfo, 15, VT_I4, 0, NULL, NULL);
-    ok( res == ERROR_SUCCESS , "Failed to set summary info\n" );
-
-    res = MsiSummaryInfoPersist(suminfo);
-    ok( res == ERROR_SUCCESS , "Failed to make summary info persist\n" );
-
-    res = MsiCloseHandle( suminfo);
-    ok( res == ERROR_SUCCESS , "Failed to close suminfo\n" );
-
-    sprintf(szPackage,"#%li",(DWORD)hdb);
-    res = MsiOpenPackage(szPackage,&hPackage);
-    ok( res == ERROR_SUCCESS , "Failed to open package\n" );
-
-    res = MsiCloseHandle( hdb );
-    ok( res == ERROR_SUCCESS , "Failed to close database\n" );
-
-    return hPackage;
-}
-
-static void test_createpackage(void)
-{
-    MSIHANDLE hPackage = 0;
-    UINT res;
-
-    hPackage = helper_createpackage();
-    ok ( hPackage != 0, " Failed to create package\n");
-
-    res = MsiCloseHandle( hPackage);
-    ok( res == ERROR_SUCCESS , "Failed to close package\n" );
-}
-
 static void test_msidatabase(void)
 {
     MSIHANDLE hdb = 0;
@@ -433,5 +357,4 @@ START_TEST(db)
     test_msiinsert();
     test_msidecomposedesc();
     test_msibadqueries();
-    test_createpackage();
 }
Index: dlls/msi/tests/record.c
===================================================================
RCS file: /home/wine/wine/dlls/msi/tests/record.c,v
retrieving revision 1.7
diff -u -p -r1.7 record.c
--- dlls/msi/tests/record.c	19 Apr 2005 09:48:44 -0000	1.7
+++ dlls/msi/tests/record.c	27 May 2005 17:02:39 -0000
@@ -220,6 +220,10 @@ void test_msirecord(void)
     r = MsiRecordReadStream(h, 0, buf, &sz);
     ok(r == ERROR_INVALID_DATATYPE, "read non-stream type\n");
     ok(sz == sizeof buf, "set sz\n");
+    r = MsiRecordDataSize( h, -1);
+    ok(r == 0,"MsiRecordDataSize returned wrong size\n");
+    r = MsiRecordDataSize( h, 0);
+    ok(r == 4,"MsiRecordDataSize returned wrong size\n");
 
     /* same record, now close it */
     r = MsiCloseHandle(h);
@@ -279,6 +283,8 @@ void test_msirecord(void)
     r = MsiRecordReadStream(h, 1, NULL, &sz);
     ok(r == ERROR_SUCCESS, "bytes left wrong after reset\n");
     ok(sz==26,"couldn't get size of stream\n");
+    r = MsiRecordDataSize(h,1);
+    ok(r == 26,"MsiRecordDataSize returned wrong size\n");
 
     /* now close the stream record */
     r = MsiCloseHandle(h);
--- /dev/null	2005-04-04 08:07:08.000000000 +0900
+++ dlls/msi/tests/format.c	2005-05-28 01:58:17.000000000 +0900
@@ -0,0 +1,796 @@
+/*
+ * Copyright (C) 2005 Mike McCormack for CodeWeavers
+ * Copyright (C) 2005 Aric Stewart for CodeWeavers
+ *
+ * A test program for MSI record formatting
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
+ */
+
+#include <stdio.h>
+#include <windows.h>
+#include <msi.h>
+#include <msiquery.h>
+
+#include "wine/test.h"
+
+static MSIHANDLE helper_createpackage( const char *szName )
+{
+    MSIHANDLE hdb = 0;
+    UINT res;
+    CHAR szPackage[10];
+    MSIHANDLE hPackage;
+    MSIHANDLE suminfo;
+
+    DeleteFile(szName);
+
+    /* create an empty database */
+    res = MsiOpenDatabase(szName, MSIDBOPEN_CREATE, &hdb );
+    ok( res == ERROR_SUCCESS , "Failed to create database\n" );
+
+    res = MsiDatabaseCommit( hdb );
+    ok( res == ERROR_SUCCESS , "Failed to commit database\n" );
+
+    /* build summmary info */
+    res = MsiGetSummaryInformation(hdb, NULL, 7, &suminfo);
+    ok( res == ERROR_SUCCESS , "Failed to open summaryinfo\n" );
+
+    res = MsiSummaryInfoSetProperty(suminfo,2, VT_LPSTR, 0,NULL,
+                        "Installation Database");
+    ok( res == ERROR_SUCCESS , "Failed to set summary info\n" );
+
+    res = MsiSummaryInfoSetProperty(suminfo,3, VT_LPSTR, 0,NULL,
+                        "Installation Database");
+    ok( res == ERROR_SUCCESS , "Failed to set summary info\n" );
+
+    res = MsiSummaryInfoSetProperty(suminfo,4, VT_LPSTR, 0,NULL,
+                        "Wine Hackers");
+    ok( res == ERROR_SUCCESS , "Failed to set summary info\n" );
+
+    res = MsiSummaryInfoSetProperty(suminfo,7, VT_LPSTR, 0,NULL,
+                    ";1033");
+    ok( res == ERROR_SUCCESS , "Failed to set summary info\n" );
+
+    res = MsiSummaryInfoSetProperty(suminfo,9, VT_LPSTR, 0,NULL,
+                    "{913B8D18-FBB6-4CAC-A239-C74C11E3FA74}");
+    ok( res == ERROR_SUCCESS , "Failed to set summary info\n" );
+
+    res = MsiSummaryInfoSetProperty(suminfo, 14, VT_I4, 100, NULL, NULL);
+    ok( res == ERROR_SUCCESS , "Failed to set summary info\n" );
+
+    res = MsiSummaryInfoSetProperty(suminfo, 15, VT_I4, 0, NULL, NULL);
+    ok( res == ERROR_SUCCESS , "Failed to set summary info\n" );
+
+    res = MsiSummaryInfoPersist(suminfo);
+    ok( res == ERROR_SUCCESS , "Failed to make summary info persist\n" );
+
+    res = MsiCloseHandle( suminfo);
+    ok( res == ERROR_SUCCESS , "Failed to close suminfo\n" );
+
+    sprintf(szPackage,"#%li",(DWORD)hdb);
+    res = MsiOpenPackage(szPackage,&hPackage);
+    ok( res == ERROR_SUCCESS , "Failed to open package\n" );
+
+    res = MsiCloseHandle( hdb );
+    ok( res == ERROR_SUCCESS , "Failed to close database\n" );
+
+    return hPackage;
+}
+
+static void test_createpackage(void)
+{
+    static const CHAR filename[] = "winetest.msi";
+    MSIHANDLE hPackage = 0;
+    UINT res;
+
+    hPackage = helper_createpackage( filename );
+    ok ( hPackage != 0, " Failed to create package\n");
+
+    res = MsiCloseHandle( hPackage);
+    ok( res == ERROR_SUCCESS , "Failed to close package\n" );
+
+    DeleteFile( filename );
+}
+
+static void test_formatrecord(void)
+{
+    char buffer[100];
+    MSIHANDLE hrec;
+    UINT r;
+    DWORD sz=100;
+
+    r = MsiFormatRecord(0, 0, NULL, NULL );
+    ok( r == ERROR_INVALID_HANDLE, "wrong error\n");
+
+    hrec = MsiCreateRecord(4);
+    ok( hrec, "failed to create record\n");
+
+    /* format an empty record */
+    r = MsiFormatRecord(0, hrec, NULL, NULL );
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    buffer[0] = 'x';
+    buffer[1] = 0;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed with empty buffer\n");
+    ok( sz == 16, "size wrong\n");
+    ok( 0 == strcmp(buffer,"1:  2:  3:  4:  "), "wrong output\n");
+
+    r = MsiCloseHandle(hrec);
+    ok(r==ERROR_SUCCESS, "Unable to close record\n");
+
+    hrec = MsiCreateRecord(6);
+    ok( hrec, "failed to create record\n");
+
+    sz = 100;
+    buffer[0] = 'x';
+    buffer[1] = 0;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed with empty buffer\n");
+    ok( sz == 24, "size wrong\n");
+    ok( 0 == strcmp(buffer,"1:  2:  3:  4:  5:  6:  "), "wrong output\n");
+
+
+    /* format a format string with everything else empty */
+    r = MsiRecordSetString(hrec, 0, "%1");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    r = MsiFormatRecord(0, hrec, NULL, NULL );
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    r = MsiFormatRecord(0, hrec, buffer, NULL);
+    ok( r == ERROR_INVALID_PARAMETER, "wrong error\n");
+
+    sz = 123;
+    r = MsiFormatRecord(0, hrec, NULL, &sz);
+    ok( r == ERROR_SUCCESS, "format failed with empty buffer\n");
+    ok( sz == 2, "size wrong (%li)\n",sz);
+    sz = sizeof buffer;
+    buffer[0] = 'x';
+    buffer[1] = 0;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed with empty buffer\n");
+    ok( sz == 2, "size wrong\n");
+    ok( 0 == strcmp(buffer,"%1"), "wrong output\n");
+
+    /* make the buffer too small */
+    sz = 0;
+    buffer[0] = 'x';
+    buffer[1] = 0;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_MORE_DATA, "format failed with empty buffer\n");
+    ok( sz == 2, "size wrong\n");
+    ok( 0 == strcmp(buffer,"x"), "wrong output\n");
+
+    /* make the buffer a little bit bigger */
+    sz = 1;
+    buffer[0] = 'x';
+    buffer[1] = 0;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_MORE_DATA, "format failed with empty buffer\n");
+    ok( sz == 2, "size wrong\n");
+    ok( 0 == strcmp(buffer,""), "wrong output (%s)\n",buffer);
+
+    /* and again */
+    sz = 2;
+    buffer[0] = 'x';
+    buffer[1] = 0;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_MORE_DATA, "format failed with empty buffer\n");
+    ok( sz == 2, "size wrong\n");
+    ok( 0 == strcmp(buffer,"%"), "wrong output\n");
+
+    /* and again */
+    sz = 3;
+    buffer[0] = 'x';
+    buffer[1] = 0;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed with empty buffer\n");
+    ok( sz == 2, "size wrong\n");
+    ok( 0 == strcmp(buffer,"%1"), "wrong output\n");
+
+    /* now try a real format string */
+    r = MsiRecordSetString(hrec, 0, "[1]");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    ok( sz == 0, "size wrong\n");
+    ok( 0 == strcmp(buffer,""), "wrong output\n");
+
+    /* now put something in the first field */
+    r = MsiRecordSetString(hrec, 1, "boo hoo");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    ok( sz == 7, "size wrong\n");
+    ok( 0 == strcmp(buffer,"boo hoo"), "wrong output\n");
+
+    /* now put something in the first field */
+    r = MsiRecordSetString(hrec, 0, "[1] [2]");
+    r = MsiRecordSetString(hrec, 1, "boo");
+    r = MsiRecordSetString(hrec, 2, "hoo");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    ok( sz == 7, "size wrong\n");
+    ok( 0 == strcmp(buffer,"boo hoo"), "wrong output\n");
+
+
+    /* empty string */
+    r = MsiRecordSetString(hrec, 0, "");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    ok( sz == 30, "size wrong %li\n",sz);
+    ok( 0 == strcmp(buffer,"1: boo 2: hoo 3:  4:  5:  6:  "), 
+                    "wrong output(%s)\n",buffer);
+
+    /* play games with recursive lookups */
+    r = MsiRecordSetString(hrec, 0, "[[1]] [2]");
+    r = MsiRecordSetString(hrec, 1, "2");
+    r = MsiRecordSetString(hrec, 2, "hey");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    ok( sz == 7, "size wrong,(%li)\n",sz);
+    ok( 0 == strcmp(buffer,"hey hey"), "wrong output (%s)\n",buffer);
+
+    r = MsiRecordSetString(hrec, 0, "[[1]] [2]");
+    r = MsiRecordSetString(hrec, 1, "[2]");
+    r = MsiRecordSetString(hrec, 2, "hey");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    ok( sz == 9, "size wrong,(%li)\n",sz);
+    ok( 0 == strcmp(buffer,"[[2]] hey"), "wrong output (%s)\n",buffer);
+
+    r = MsiRecordSetString(hrec, 0, "[[[3]]] [2]");
+    r = MsiRecordSetString(hrec, 1, "2");
+    r = MsiRecordSetString(hrec, 2, "hey");
+    r = MsiRecordSetString(hrec, 3, "1");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    ok( sz == 7, "size wrong,(%li)\n",sz);
+    ok( 0 == strcmp(buffer,"hey hey"), "wrong output (%s)\n",buffer);
+
+    r = MsiCloseHandle(hrec);
+    ok(r==ERROR_SUCCESS, "Unable to close record\n");
+    hrec = MsiCreateRecord(12);
+    ok( hrec, "failed to create record\n");
+
+    r = MsiRecordSetString(hrec, 0, "[[3][1]] [2]");
+    r = MsiRecordSetString(hrec, 1, "2");
+    r = MsiRecordSetString(hrec, 2, "hey");
+    r = MsiRecordSetString(hrec, 3, "1");
+    r = MsiRecordSetString(hrec, 12, "big");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    ok( sz == 7, "size wrong,(%li)\n",sz);
+    ok( 0 == strcmp(buffer,"big hey"), "wrong output (%s)\n",buffer);
+
+    r = MsiRecordSetString(hrec, 0, "[[3][4][1]] [2]");
+    r = MsiRecordSetString(hrec, 1, "2");
+    r = MsiRecordSetString(hrec, 2, "hey");
+    r = MsiRecordSetString(hrec, 3, "1");
+    r = MsiRecordSetString(hrec, 4, NULL);
+    r = MsiRecordSetString(hrec, 12, "big");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    ok( sz == 7, "size wrong,(%li)\n",sz);
+    ok( 0 == strcmp(buffer,"big hey"), "wrong output (%s)\n",buffer);
+
+    r = MsiRecordSetString(hrec, 0, "[[3][[4]][1]] [2]");
+    r = MsiRecordSetString(hrec, 1, "2");
+    r = MsiRecordSetString(hrec, 2, "hey");
+    r = MsiRecordSetString(hrec, 3, "1");
+    r = MsiRecordSetString(hrec, 4, NULL);
+    r = MsiRecordSetString(hrec, 12, "big");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    ok( sz == 10, "size wrong,(%li)\n",sz);
+    ok( 0 == strcmp(buffer,"[1[]2] hey"), "wrong output (%s)\n",buffer);
+
+    /* incorrect  formats */
+    r = MsiRecordSetString(hrec, 0, "[[[3][[4]][1]] [2]");
+    r = MsiRecordSetString(hrec, 1, "2");
+    r = MsiRecordSetString(hrec, 2, "hey");
+    r = MsiRecordSetString(hrec, 3, "1");
+    r = MsiRecordSetString(hrec, 4, NULL);
+    r = MsiRecordSetString(hrec, 12, "big");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    ok( sz == 18, "size wrong,(%li)\n",sz);
+    ok( 0 == strcmp(buffer,"[[[3][[4]][1]] [2]"), "wrong output (%s)\n",buffer);
+
+    r = MsiRecordSetString(hrec, 0, "[[3][[4]][1]] [2]]");
+    r = MsiRecordSetString(hrec, 1, "2");
+    r = MsiRecordSetString(hrec, 2, "hey");
+    r = MsiRecordSetString(hrec, 3, "1");
+    r = MsiRecordSetString(hrec, 4, NULL);
+    r = MsiRecordSetString(hrec, 12, "big");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    ok( sz == 11, "size wrong,(%li)\n",sz);
+    ok( 0 == strcmp(buffer,"[1[]2] hey]"), "wrong output (%s)\n",buffer);
+
+
+    /* play games with {} */
+
+    r = MsiRecordSetString(hrec, 0, "{[3][1]} [2]");
+    r = MsiRecordSetString(hrec, 1, "2");
+    r = MsiRecordSetString(hrec, 2, "hey");
+    r = MsiRecordSetString(hrec, 3, "1");
+    r = MsiRecordSetString(hrec, 4, NULL);
+    r = MsiRecordSetString(hrec, 12, "big");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    ok( sz == 6, "size wrong,(%li)\n",sz);
+    ok( 0 == strcmp(buffer,"12 hey"), "wrong output (%s)\n",buffer);
+
+    r = MsiRecordSetString(hrec, 0, "[{[3][1]}] [2]");
+    r = MsiRecordSetString(hrec, 1, "2");
+    r = MsiRecordSetString(hrec, 2, "hey");
+    r = MsiRecordSetString(hrec, 3, "1");
+    r = MsiRecordSetString(hrec, 4, NULL);
+    r = MsiRecordSetString(hrec, 12, "big");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    ok( sz == 8, "size wrong,(%li)\n",sz);
+    ok( 0 == strcmp(buffer,"[12] hey"), "wrong output (%s)\n",buffer);
+
+
+    r = MsiRecordSetString(hrec, 0, "{test} [2]");
+    r = MsiRecordSetString(hrec, 1, "2");
+    r = MsiRecordSetString(hrec, 2, "hey");
+    r = MsiRecordSetString(hrec, 3, "1");
+    r = MsiRecordSetString(hrec, 4, NULL);
+    r = MsiRecordSetString(hrec, 12, "big");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    ok( sz == 10, "size wrong,(%li)\n",sz);
+    ok( 0 == strcmp(buffer,"{test} hey"), "wrong output (%s)\n",buffer);
+
+    r = MsiRecordSetString(hrec, 0, "{[test]} [2]");
+    r = MsiRecordSetString(hrec, 1, "2");
+    r = MsiRecordSetString(hrec, 2, "hey");
+    r = MsiRecordSetString(hrec, 3, "1");
+    r = MsiRecordSetString(hrec, 4, NULL);
+    r = MsiRecordSetString(hrec, 12, "big");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    ok( sz == 12, "size wrong,(%li)\n",sz);
+    ok( 0 == strcmp(buffer,"{[test]} hey"), "wrong output (%s)\n",buffer);
+
+    r = MsiRecordSetString(hrec, 0, "{[1][2][3][4]} [2]");
+    r = MsiRecordSetString(hrec, 1, "2");
+    r = MsiRecordSetString(hrec, 2, "hey");
+    r = MsiRecordSetString(hrec, 3, "1");
+    r = MsiRecordSetString(hrec, 4, NULL);
+    r = MsiRecordSetString(hrec, 12, "big");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    ok( sz == 4, "size wrong,(%li)\n",sz);
+    ok( 0 == strcmp(buffer," hey"), "wrong output (%s)\n",buffer);
+
+    r = MsiRecordSetString(hrec, 0, "{[1][2][3][dummy]} [2]");
+    r = MsiRecordSetString(hrec, 1, "2");
+    r = MsiRecordSetString(hrec, 2, "hey");
+    r = MsiRecordSetString(hrec, 3, "1");
+    r = MsiRecordSetString(hrec, 4, NULL);
+    r = MsiRecordSetString(hrec, 12, "big");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    ok( sz == 18, "size wrong,(%li)\n",sz);
+    ok( 0 == strcmp(buffer,"{2hey1[dummy]} hey"), "wrong output (%s)\n",buffer);
+
+    r = MsiRecordSetString(hrec, 0, "{[1][2][3][4][dummy]} [2]");
+    r = MsiRecordSetString(hrec, 1, "2");
+    r = MsiRecordSetString(hrec, 2, "hey");
+    r = MsiRecordSetString(hrec, 3, "1");
+    r = MsiRecordSetString(hrec, 4, NULL);
+    r = MsiRecordSetString(hrec, 12, "big");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    ok( sz == 18, "size wrong,(%li)\n",sz);
+    ok( 0 == strcmp(buffer,"{2hey1[dummy]} hey"), "wrong output (%s)\n",buffer);
+
+    r = MsiRecordSetString(hrec, 0, "{{[1][2]}[3][4][dummy]}");
+    r = MsiRecordSetString(hrec, 1, "2");
+    r = MsiRecordSetString(hrec, 2, "hey");
+    r = MsiRecordSetString(hrec, 3, "1");
+    r = MsiRecordSetString(hrec, 4, NULL);
+    r = MsiRecordSetString(hrec, 12, "big");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+
+    todo_wine{
+    ok( sz == 16, "size wrong,(%li)\n",sz);
+    ok( 0 == strcmp(buffer,"{{2hey}1[dummy]}"), "wrong output (%s)\n",buffer);
+    }
+
+    r = MsiRecordSetString(hrec, 0, "{{[1][2]}[3]{[4][dummy]}}");
+    r = MsiRecordSetString(hrec, 1, "2");
+    r = MsiRecordSetString(hrec, 2, "hey");
+    r = MsiRecordSetString(hrec, 3, "1");
+    r = MsiRecordSetString(hrec, 4, NULL);
+    r = MsiRecordSetString(hrec, 12, "big");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    todo_wine{
+    ok( sz == 0, "size wrong,(%li)\n",sz);
+    ok( 0 == strcmp(buffer,""), "wrong output (%s)\n",buffer);
+    }
+
+    r = MsiRecordSetString(hrec, 0, "{{[1][2]}[3]} {[1][2]}");
+    r = MsiRecordSetString(hrec, 1, "1");
+    r = MsiRecordSetString(hrec, 2, "2");
+    r = MsiRecordSetString(hrec, 3, "3");
+    r = MsiRecordSetString(hrec, 4, NULL);
+    r = MsiRecordSetString(hrec, 12, "big");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    todo_wine{
+    ok( sz == 12, "size wrong,(%li)\n",sz);
+    ok( 0 == strcmp(buffer,"{{12}3} {12}"), "wrong output (%s)\n",buffer);
+    }
+
+    r = MsiRecordSetString(hrec, 0, "{[1][2]} {{[1][2]}[3]} {[1][2]}");
+    r = MsiRecordSetString(hrec, 1, "1");
+    r = MsiRecordSetString(hrec, 2, "2");
+    r = MsiRecordSetString(hrec, 3, "3");
+    r = MsiRecordSetString(hrec, 4, NULL);
+    r = MsiRecordSetString(hrec, 12, "big");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    todo_wine{
+    ok( sz == 15, "size wrong,(%li)\n",sz);
+    ok( 0 == strcmp(buffer,"12 {{12}3} {12}"), "wrong output (%s)\n",buffer);
+    }
+
+    r = MsiRecordSetString(hrec, 0, "{[4]}{[1][2]} {{[1][2]}[3]} {[1][2]}");
+    r = MsiRecordSetString(hrec, 1, "1");
+    r = MsiRecordSetString(hrec, 2, "2");
+    r = MsiRecordSetString(hrec, 3, "3");
+    r = MsiRecordSetString(hrec, 4, NULL);
+    r = MsiRecordSetString(hrec, 12, "big");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    todo_wine{
+    ok( sz == 15, "size wrong,(%li)\n",sz);
+    ok( 0 == strcmp(buffer,"12 {{12}3} {12}"), "wrong output (%s)\n",buffer);
+    }
+
+
+    r = MsiRecordSetString(hrec, 0, "{blah} {[4]}{[1][2]} {{[1][2]}[3]} {[1][2]}");
+    r = MsiRecordSetString(hrec, 1, "1");
+    r = MsiRecordSetString(hrec, 2, "2");
+    r = MsiRecordSetString(hrec, 3, "3");
+    r = MsiRecordSetString(hrec, 4, NULL);
+    r = MsiRecordSetString(hrec, 12, "big");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    todo_wine{
+    ok( sz == 22, "size wrong,(%li)\n",sz);
+    ok( 0 == strcmp(buffer,"{blah} 12 {{12}3} {12}"), "wrong output (%s)\n",buffer);
+    }
+
+    r = MsiRecordSetString(hrec, 0, "{{[1]}[2]} {[4]}{[1][2]}");
+    r = MsiRecordSetString(hrec, 1, "1");
+    r = MsiRecordSetString(hrec, 2, "2");
+    r = MsiRecordSetString(hrec, 3, "3");
+    r = MsiRecordSetString(hrec, 4, NULL);
+    r = MsiRecordSetString(hrec, 12, "big");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    todo_wine{
+    ok( sz == 13, "size wrong,(%li)\n",sz);
+    ok( 0 == strcmp(buffer,"{{1}2} {}{12}"), "wrong output (%s)\n",buffer);
+    }
+
+    r = MsiRecordSetString(hrec, 0, "{{[1]}} {[4]}{[1][2]}");
+    r = MsiRecordSetString(hrec, 1, "1");
+    r = MsiRecordSetString(hrec, 2, "2");
+    r = MsiRecordSetString(hrec, 3, "3");
+    r = MsiRecordSetString(hrec, 4, NULL);
+    r = MsiRecordSetString(hrec, 12, "big");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    todo_wine{
+    ok( sz == 3, "size wrong,(%li)\n",sz);
+    ok( 0 == strcmp(buffer," 12"), "wrong output (%s)\n",buffer);
+    }
+
+    r = MsiRecordSetString(hrec, 0, "{{{[1]}} {[4]}{[1][2]}");
+    r = MsiRecordSetString(hrec, 1, "1");
+    r = MsiRecordSetString(hrec, 2, "2");
+    r = MsiRecordSetString(hrec, 3, "3");
+    r = MsiRecordSetString(hrec, 4, NULL);
+    r = MsiRecordSetString(hrec, 12, "big");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    todo_wine{
+    ok( sz == 3, "size wrong,(%li)\n",sz);
+    ok( 0 == strcmp(buffer," 12"), "wrong output (%s)\n",buffer);
+    }
+    
+    /* now put play games with escaping */
+    r = MsiRecordSetString(hrec, 0, "[1] [2] [\\3asdf]");
+    r = MsiRecordSetString(hrec, 1, "boo");
+    r = MsiRecordSetString(hrec, 2, "hoo");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    ok( sz == 16, "size wrong\n");
+    ok( 0 == strcmp(buffer,"boo hoo [\\3asdf]"), "wrong output\n");
+
+    /* now put play games with escaping */
+    r = MsiRecordSetString(hrec, 0, "[1] [2] [\\x]");
+    r = MsiRecordSetString(hrec, 1, "boo");
+    r = MsiRecordSetString(hrec, 2, "hoo");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    ok( sz == 12, "size wrong\n");
+    ok( 0 == strcmp(buffer,"boo hoo [\\x]"), "wrong output\n");
+
+    /* now try other formats without a package */
+    r = MsiRecordSetString(hrec, 0, "[1] [2] [property]");
+    r = MsiRecordSetString(hrec, 1, "boo");
+    r = MsiRecordSetString(hrec, 2, "hoo");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    ok( sz == 18, "size wrong\n");
+    ok( 0 == strcmp(buffer,"boo hoo [property]"), "wrong output\n");
+
+    r = MsiRecordSetString(hrec, 0, "[1] [~] [2]");
+    r = MsiRecordSetString(hrec, 1, "boo");
+    r = MsiRecordSetString(hrec, 2, "hoo");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(0, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    ok( sz == 11, "size wrong\n");
+    ok( 0 == strcmp(buffer,"boo [~] hoo"), "wrong output (%s)\n",buffer);
+}
+
+static void test_formatrecord_package(void)
+{
+    static const CHAR filename[] = "winetest.msi";
+    char buffer[100];
+    MSIHANDLE hrec;
+    MSIHANDLE package;
+    UINT r;
+    DWORD sz=100;
+
+    package = helper_createpackage( filename );
+    ok(package!=0, "Unable to create package\n");
+
+    hrec = MsiCreateRecord(12);
+    ok( hrec, "failed to create record\n");
+
+    r = MsiFormatRecord(package, 0, NULL, NULL );
+    ok( r == ERROR_INVALID_HANDLE, "wrong error\n");
+
+    r = MsiFormatRecord(package, hrec, NULL, NULL );
+    ok( r == ERROR_SUCCESS, "format failed\n");
+
+    r = MsiRecordSetString(hrec,0,NULL);
+    r = MsiRecordSetString(hrec,1,NULL);
+    r = MsiRecordSetString(hrec,2,NULL);
+    r = MsiRecordSetString(hrec,3,NULL);
+    r = MsiRecordSetString(hrec,4,NULL);
+    r = MsiRecordSetString(hrec,5,NULL);
+    r = MsiRecordSetString(hrec,6,NULL);
+    r = MsiRecordSetString(hrec,7,NULL);
+    r = MsiRecordSetString(hrec,8,NULL);
+    r = MsiRecordSetString(hrec,9,NULL);
+    r = MsiRecordSetString(hrec,10,NULL);
+    r = MsiRecordSetString(hrec,11,NULL);
+    r = MsiRecordSetString(hrec,12,NULL);
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+
+    sz = sizeof buffer;
+    r = MsiFormatRecord(package, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed with empty buffer (%i)\n",r);
+    ok( sz == 51, "size wrong (%li)\n",sz);
+    ok( 0 == strcmp(buffer,"1:  2:  3:  4:  5:  6:  7:  8:  9:  10:  11:  12:  "), "wrong output(%s)\n",buffer);
+
+    /* now put play games with escaping */
+    r = MsiRecordSetString(hrec, 0, "[1] [2] [\\3asdf]");
+    r = MsiRecordSetString(hrec, 1, "boo");
+    r = MsiRecordSetString(hrec, 2, "hoo");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(package, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    ok( sz == 9, "size wrong(%li)\n",sz);
+    ok( 0 == strcmp(buffer,"boo hoo 3"), "wrong output (%s)\n",buffer);
+
+    r = MsiRecordSetString(hrec, 0, "[1] [2] [\\x]");
+    r = MsiRecordSetString(hrec, 1, "boo");
+    r = MsiRecordSetString(hrec, 2, "hoo");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(package, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    ok( sz == 9, "size wrong(%li)\n",sz);
+    ok( 0 == strcmp(buffer,"boo hoo x"), "wrong output (%s)\n",buffer);
+
+    /* null characters */
+    r = MsiRecordSetString(hrec, 0, "[1] [~] [2]");
+    r = MsiRecordSetString(hrec, 1, "boo");
+    r = MsiRecordSetString(hrec, 2, "hoo");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(package, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    ok( sz == 9, "size wrong\n");
+    ok( 0 == strcmp(buffer,"boo "), "wrong output\n");
+
+    /* properties */
+    r = MsiSetProperty(package,"dummy","Bork");
+    ok( r == ERROR_SUCCESS, "set property failed\n");
+    r = MsiRecordSetString(hrec, 0, "[1] [dummy] [2]");
+    r = MsiRecordSetString(hrec, 1, "boo");
+    r = MsiRecordSetString(hrec, 2, "hoo");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(package, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    ok( sz == 12, "size wrong\n");
+    ok( 0 == strcmp(buffer,"boo Bork hoo"), "wrong output\n");
+
+    r = MsiRecordSetString(hrec, 0, "[1] [invalid] [2]");
+    r = MsiRecordSetString(hrec, 1, "boo");
+    r = MsiRecordSetString(hrec, 2, "hoo");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(package, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    ok( sz == 8, "size wrong\n");
+    ok( 0 == strcmp(buffer,"boo  hoo"), "wrong output\n");
+
+
+    /* nesting tests */
+    r = MsiSetProperty(package,"dummya","foo");
+    r = MsiSetProperty(package,"dummyb","baa");
+    r = MsiSetProperty(package,"adummyc","whoa");
+    ok( r == ERROR_SUCCESS, "set property failed\n");
+    r = MsiRecordSetString(hrec, 0, "[dummy[1]] [dummy[2]] [[1]dummy[3]]");
+    r = MsiRecordSetString(hrec, 1, "a");
+    r = MsiRecordSetString(hrec, 2, "b");
+    r = MsiRecordSetString(hrec, 3, "c");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(package, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    ok( sz == 12, "size wrong(%li)\n",sz);
+    ok( 0 == strcmp(buffer,"foo baa whoa"), "wrong output (%s)\n",buffer);
+
+
+    r = MsiSetProperty(package,"dummya","1");
+    r = MsiSetProperty(package,"dummyb","[2]");
+    ok( r == ERROR_SUCCESS, "set property failed\n");
+    r = MsiRecordSetString(hrec, 0, "[dummya] [[dummya]] [dummyb]");
+    r = MsiRecordSetString(hrec, 1, "aaa");
+    r = MsiRecordSetString(hrec, 2, "bbb");
+    r = MsiRecordSetString(hrec, 3, "ccc");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(package, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    ok( sz == 9, "size wrong(%li)\n",sz);
+    ok( 0 == strcmp(buffer,"1 [1] [2]"), "wrong output (%s)\n",buffer);
+
+    r = MsiSetProperty(package,"dummya","1");
+    r = MsiSetProperty(package,"dummyb","a");
+    r = MsiSetProperty(package,"dummyc","\\blath");
+    r = MsiSetProperty(package,"dummyd","[\\blath]");
+    ok( r == ERROR_SUCCESS, "set property failed\n");
+    r = MsiRecordSetString(hrec, 0, "[dummyc] [[dummyc]] [dummy[dummyb]]");
+    r = MsiRecordSetString(hrec, 1, "aaa");
+    r = MsiRecordSetString(hrec, 2, "bbb");
+    r = MsiRecordSetString(hrec, 3, "ccc");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(package, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    ok( sz == 10, "size wrong(%li)\n",sz);
+    ok( 0 == strcmp(buffer,"\\blath b 1"), "wrong output (%s)\n",buffer);
+
+    r = MsiRecordSetString(hrec, 0, "[1] [2] [[\\3asdf]]");
+    r = MsiRecordSetString(hrec, 1, "boo");
+    r = MsiRecordSetString(hrec, 2, "hoo");
+    r = MsiRecordSetString(hrec, 3, "yeah");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(package, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    ok( sz == 11, "size wrong(%li)\n",sz);
+    ok( 0 == strcmp(buffer,"boo hoo [3]"), "wrong output (%s)\n",buffer);
+
+    r = MsiRecordSetString(hrec, 0, "[1] [2] [[3]]");
+    r = MsiRecordSetString(hrec, 1, "boo");
+    r = MsiRecordSetString(hrec, 2, "hoo");
+    r = MsiRecordSetString(hrec, 3, "\\help");
+    ok( r == ERROR_SUCCESS, "set string failed\n");
+    sz = sizeof buffer;
+    r = MsiFormatRecord(package, hrec, buffer, &sz);
+    ok( r == ERROR_SUCCESS, "format failed\n");
+    ok( sz == 9, "size wrong(%li)\n",sz);
+    ok( 0 == strcmp(buffer,"boo hoo h"), "wrong output (%s)\n",buffer);
+
+    r = MsiCloseHandle(package);
+    ok(r==ERROR_SUCCESS, "Unable to close package\n");
+
+    DeleteFile( filename );
+}
+
+START_TEST(format)
+{
+    test_createpackage();
+    test_formatrecord();
+    test_formatrecord_package();
+}


More information about the wine-patches mailing list