changeset 207:e35983a322d6

merged.
author Raimund Renkert <rrenkert@intevation.de>
date Wed, 26 Mar 2014 15:22:50 +0100 (2014-03-26)
parents d587d075eddc (current diff) 825b42da1855 (diff)
children 135eae057491
files ui/tests/data/garbage_2MB ui/tests/data/garbage_500KB
diffstat 7 files changed, 62 insertions(+), 13 deletions(-) [+]
line wrap: on
line diff
--- a/ui/certificate.cpp	Wed Mar 26 15:22:14 2014 +0100
+++ b/ui/certificate.cpp	Wed Mar 26 15:22:50 2014 +0100
@@ -15,6 +15,10 @@
 
     x509_crt x509cert;
 
+    if (b64Line.isEmpty()) {
+        return;
+    }
+
     /* Cut of the first two chars (e.g. I: and decode) */
     QByteArray asn1data = QByteArray::fromBase64(
             b64Line.right(b64Line.size() - 2).toLatin1());
@@ -25,6 +29,7 @@
                          asn1data.size());
     if (ret != 0) {
         qDebug() << "Parsing certificate failed with error: " << ret;
+        qDebug() << "Failed cert: " << asn1data.toBase64();
         x509_crt_free(&x509cert);
         return;
     }
--- a/ui/certificatelist.cpp	Wed Mar 26 15:22:14 2014 +0100
+++ b/ui/certificatelist.cpp	Wed Mar 26 15:22:50 2014 +0100
@@ -13,6 +13,11 @@
     char *data = NULL;
     size_t size = 0;
 
+    mCertificatesRemove.clear();
+    mCertificatesInstall.clear();
+    mDate = QDateTime();
+    mData = QString();
+
     mStatus = read_and_verify_list(fileName, &data, &size);
 
     if (!isValid()) {
--- a/ui/certificatelist.h	Wed Mar 26 15:22:14 2014 +0100
+++ b/ui/certificatelist.h	Wed Mar 26 15:22:50 2014 +0100
@@ -54,7 +54,6 @@
     const QString& rawData() const {return mData;}
 
 private:
-    QString mFileName;
     QList<Certificate> mCertificatesInstall;
     QList<Certificate> mCertificatesRemove;
     QString mData;
--- a/ui/tests/certlistparsertest.cpp	Wed Mar 26 15:22:14 2014 +0100
+++ b/ui/tests/certlistparsertest.cpp	Wed Mar 26 15:22:50 2014 +0100
@@ -51,9 +51,16 @@
     QVERIFY(instLines.size() == instList.size());
     QVERIFY(remoLines.size() == remoList.size());
 
+    /* Check that a default certificate is invalid */
     Certificate cert;
     QVERIFY(!cert.isValid());
 
+    certList->readList(fileName.toLocal8Bit().data());
+
+    const QList<Certificate> instList2 = certList->getInstallCertificates();
+    const QList<Certificate> remoList2 = certList->getRemoveCertificates();
+    QVERIFY(instLines.size() == instList2.size());
+    QVERIFY(remoLines.size() == remoList2.size());
 
     delete certList;
 }
@@ -90,29 +97,61 @@
 {
     const char *fname = "empty_file";
     CertificateList *certList = testWithFile(fname);
-    printf("Status :%i\n ",certList->getStatus());
     QCOMPARE (certList->getStatus(), SeekFailed);
     delete certList;
 }
 
 void CertListTest::testGarbage()
 {
-    const char *fnames[] = {"garbage_500KB",
-        "list-with-null.txt",
-        NULL};
-    for (int i=0; fnames[i] != NULL; i++) {
-        CertificateList *certList = testWithFile(fnames[i]);
-        QCOMPARE (certList->getStatus(), InvalidFormat);
-        delete certList;
+    const char *fname = "list-with-null.txt";
+    QString fname2 = getRandomDataFile(200);
+    CertificateList *certList = testWithFile(fname);
+    QCOMPARE (certList->getStatus(), InvalidFormat);
+    delete certList;
+    certList = testWithFile(fname2.toLocal8Bit().constData());
+    QVERIFY(QFile::remove(fname2));
+    QCOMPARE (certList->getStatus(), InvalidFormat);
+    delete certList;
+}
+
+QString CertListTest::getRandomDataFile(size_t size)
+{
+    QTemporaryFile tmpfile;
+    tmpfile.setAutoRemove(false);
+    tmpfile.open();
+    size_t bufsize = 1024 * 1024;
+    if (bufsize > size) {
+        bufsize = size;
     }
+    char buf[bufsize];
+
+    for (size_t i = 0; i < bufsize; i++) {
+        buf[i] = (char) qrand() % 255;
+    }
+
+    size_t bytesWritten=0;
+    int retval = 0;
+    do {
+        size_t toWrite = size - bytesWritten;
+        if (toWrite < bufsize) {
+            retval = tmpfile.write(buf, toWrite);
+        } else {
+            retval = tmpfile.write(buf, bufsize);
+        }
+        bytesWritten += retval;
+    } while (retval != -1 && bytesWritten < size);
+
+    tmpfile.close();
+    return tmpfile.fileName();
 }
 
 void CertListTest::testTooLarge()
 {
-    const char *fname = "garbage_2MB";
-    CertificateList *certList = testWithFile(fname);
-    QCOMPARE (certList->getStatus(), TooLarge);
-    QVERIFY (!certList->isValid());
+    QString fname = getRandomDataFile(MAX_LINE_LENGTH * MAX_LINES + 1);
+    CertificateList *certList = testWithFile(fname.toLocal8Bit().constData());
+    QVERIFY(QFile::remove(fname));
+    QCOMPARE(certList->getStatus(), TooLarge);
+    QVERIFY(!certList->isValid());
     delete certList;
 }
 
--- a/ui/tests/certlistparsertest.h	Wed Mar 26 15:22:14 2014 +0100
+++ b/ui/tests/certlistparsertest.h	Wed Mar 26 15:22:50 2014 +0100
@@ -11,6 +11,7 @@
     Q_OBJECT
 
     CertificateList* testWithFile(const char *filename);
+    QString getRandomDataFile(size_t size);
 
 private Q_SLOTS:
     void testInvalidSig();
Binary file ui/tests/data/garbage_2MB has changed
Binary file ui/tests/data/garbage_500KB has changed

http://wald.intevation.org/projects/trustbridge/