20 #include "CUnit/CUnit.h" 48 for(i=0; i<20; i++) { sprintf(Fuid+0+i*2,
"%02X",
's'); }
50 for(i=0; i<16; i++) { sprintf(Fuid+41+i*2,
"%02X",
'm'); }
52 snprintf(Fuid+74,
sizeof(Fuid)-74,
"%Lu",(
long long unsigned int)100);
60 snprintf(SQL,MAXSQL,
"INSERT INTO pfile (pfile_sha1,pfile_md5,pfile_size) VALUES ('%.40s','%.32s','%s');",
61 Fuid,Fuid+41,Fuid+74);
65 printf(
"Perpare pfile information ERROR!\n");
71 memset(SQL,
'\0',MAXSQL);
72 snprintf(SQL,MAXSQL,
"SELECT pfile_pk FROM pfile WHERE pfile_sha1 = '%.40s' AND pfile_md5 = '%.32s' AND pfile_size = '%s';",
73 Fuid,Fuid+41,Fuid+74);
77 printf(
"Get pfile information ERROR!\n");
82 pi->
pFileFk = atoi(PQgetvalue(result, 0, 0));
94 strncpy(pi->
group,
"Test group",
sizeof(pi->
group));
95 strncpy(pi->
url,
"Test url",
sizeof(pi->
url));
101 pi->
requires = calloc(data_size,
sizeof(
char *));
102 for (j=0; j<data_size;j++){
104 strcpy(pi->
requires[j],
"Test requires");
110 printf(
"RecordMetadataRPM Result is:%d\n", Result);
113 memset(SQL,
'\0',MAXSQL);
114 snprintf(SQL,MAXSQL,
"SELECT pkg_pk, pkg_name, pkg_arch, version, license, packager, release, vendor FROM pkg_rpm INNER JOIN pfile ON pfile_fk = '%ld' AND pfile_fk = pfile_pk;", pi->
pFileFk);
118 printf(
"Get pkg information ERROR!\n");
123 CU_ASSERT_STRING_EQUAL(PQgetvalue(result, 0, 1),
"Test Pkg");
124 CU_ASSERT_STRING_EQUAL(PQgetvalue(result, 0, 2),
"Test Arch");
125 CU_ASSERT_STRING_EQUAL(PQgetvalue(result, 0, 3),
"Test version");
126 CU_ASSERT_STRING_EQUAL(PQgetvalue(result, 0, 4),
"Test license");
127 CU_ASSERT_STRING_EQUAL(PQgetvalue(result, 0, 5),
"Test packager");
128 CU_ASSERT_STRING_EQUAL(PQgetvalue(result, 0, 6),
"Test release");
129 CU_ASSERT_STRING_EQUAL(PQgetvalue(result, 0, 7),
"Test vendor");
133 memset(SQL,
'\0',MAXSQL);
134 snprintf(SQL,MAXSQL,
"DELETE FROM pkg_rpm_req WHERE pkg_fk IN (SELECT pkg_pk FROM pkg_rpm WHERE pfile_fk = '%ld');", pi->
pFileFk);
138 printf(
"Clear pkg_rpm_req test data ERROR!\n");
144 memset(SQL,
'\0',MAXSQL);
145 snprintf(SQL,MAXSQL,
"DELETE FROM pkg_rpm WHERE pfile_fk = '%ld';", pi->
pFileFk);
149 printf(
"Clear pkg_rpm test data ERROR!\n");
153 memset(SQL,
'\0',MAXSQL);
154 snprintf(SQL,MAXSQL,
"DELETE FROM pfile WHERE pfile_pk = '%ld'", pi->
pFileFk);
158 printf(
"Clear pfile test data ERROR!\n");
172 CU_ASSERT_EQUAL(Result, predictValue);
static int Result
Result of calls.
int fo_checkPQresult(PGconn *pgConn, PGresult *result, char *sql, char *FileID, int LineNumb)
Check the result status of a postgres SELECT.
char license[512]
RPM licenses.
char description[MAXCMD]
Package description.
int RecordMetadataRPM(struct rpmpkginfo *pi)
Store rpm package info into database.
char packager[1024]
Packager.
char buildDate[128]
Package build date.
char sourceRPM[256]
Package source.
char pkgName[256]
RPM package name.
Holds meta info of rpm packages.
char version[64]
Package version.
char ** requires
Package dependency list.
int fo_checkPQcommand(PGconn *pgConn, PGresult *result, char *sql, char *FileID, int LineNumb)
Check the result status of a postgres commands (not select) If an error occured, write the error to s...
char SQL[256]
SQL query to execute.
char summary[MAXCMD]
Package summary.
char pkgAlias[256]
Package alias.
char pkgArch[64]
Package architecture.
PGconn * db_conn
The connection to Database.
char rpmFilename[256]
RPM file name.
char vendor[128]
Package vendor.
char group[128]
Package group.
char release[64]
Package release.
char url[256]
Package link.
int req_size
Package dependency list size.
long pFileFk
Package pfile in FOSSology.
PGconn * fo_dbconnect(char *DBConfFile, char **ErrorBuf)
Connect to a database. The default is Db.conf.