Blame glib/tests/base64.c

Packit ae235b
#include <glib.h>
Packit ae235b
#include <string.h>
Packit ae235b
#include <stdlib.h>
Packit ae235b
Packit ae235b
#define DATA_SIZE 1024
Packit ae235b
#define BLOCK_SIZE 32
Packit ae235b
#define NUM_BLOCKS 32
Packit ae235b
static guchar data[DATA_SIZE];
Packit ae235b
Packit ae235b
static void
Packit ae235b
test_incremental (gboolean line_break,
Packit ae235b
                  gint     length)
Packit ae235b
{
Packit ae235b
  char *p;
Packit ae235b
  gsize len, decoded_len, max, input_len, block_size;
Packit ae235b
  int state, save;
Packit ae235b
  guint decoder_save;
Packit ae235b
  char *text;
Packit ae235b
  guchar *data2;
Packit ae235b
Packit ae235b
  data2 = g_malloc (length);
Packit ae235b
  text = g_malloc (length * 4);
Packit ae235b
Packit ae235b
  len = 0;
Packit ae235b
  state = 0;
Packit ae235b
  save = 0;
Packit ae235b
  input_len = 0;
Packit ae235b
  while (input_len < length)
Packit ae235b
    {
Packit ae235b
      block_size = MIN (BLOCK_SIZE, length - input_len);
Packit ae235b
      len += g_base64_encode_step (data + input_len, block_size,
Packit ae235b
                                   line_break, text + len, &state, &save);
Packit ae235b
      input_len += block_size;
Packit ae235b
    }
Packit ae235b
  len += g_base64_encode_close (line_break, text + len, &state, &save);
Packit ae235b
Packit ae235b
  if (line_break)
Packit ae235b
    max = length * 4 / 3 + length * 4 / (3 * 72) + 7;
Packit ae235b
  else
Packit ae235b
    max = length * 4 / 3 + 6;
Packit ae235b
Packit ae235b
  /* Check encoded length */
Packit ae235b
  g_assert_cmpint (len, <=, max);
Packit ae235b
Packit ae235b
  decoded_len = 0;
Packit ae235b
  state = 0;
Packit ae235b
  decoder_save = 0;
Packit ae235b
  p = text;
Packit ae235b
  while (len > 0)
Packit ae235b
    {
Packit ae235b
      int chunk_len = MIN (BLOCK_SIZE, len);
Packit ae235b
      decoded_len += g_base64_decode_step (p,
Packit ae235b
                                           chunk_len,
Packit ae235b
                                           data2 + decoded_len,
Packit ae235b
                                           &state, &decoder_save);
Packit ae235b
      p += chunk_len;
Packit ae235b
      len -= chunk_len;
Packit ae235b
    }
Packit ae235b
Packit ae235b
  g_assert_cmpmem (data, length, data2, decoded_len);
Packit ae235b
Packit ae235b
  g_free (text);
Packit ae235b
  g_free (data2);
Packit ae235b
}
Packit ae235b
Packit ae235b
static void
Packit ae235b
test_incremental_break (gconstpointer d)
Packit ae235b
{
Packit ae235b
  gint length = GPOINTER_TO_INT (d);
Packit ae235b
Packit ae235b
  test_incremental (TRUE, length);
Packit ae235b
}
Packit ae235b
Packit ae235b
static void
Packit ae235b
test_incremental_nobreak (gconstpointer d)
Packit ae235b
{
Packit ae235b
  gint length = GPOINTER_TO_INT (d);
Packit ae235b
Packit ae235b
  test_incremental (FALSE, length);
Packit ae235b
}
Packit ae235b
Packit ae235b
static void
Packit ae235b
test_full (gconstpointer d)
Packit ae235b
{
Packit ae235b
  gint length = GPOINTER_TO_INT (d);
Packit ae235b
  char *text;
Packit ae235b
  guchar *data2;
Packit ae235b
  gsize len;
Packit ae235b
Packit ae235b
  text = g_base64_encode (data, length);
Packit ae235b
  data2 = g_base64_decode (text, &len;;
Packit ae235b
  g_free (text);
Packit ae235b
Packit ae235b
  g_assert_cmpmem (data, length, data2, len);
Packit ae235b
Packit ae235b
  g_free (data2);
Packit ae235b
}
Packit ae235b
Packit ae235b
struct MyRawData
Packit ae235b
{
Packit ae235b
  gint length;   /* of data */
Packit ae235b
  guchar data[DATA_SIZE];
Packit ae235b
};
Packit ae235b
Packit ae235b
/* 100 pre-encoded string from data[] buffer. Data length from 1..100
Packit ae235b
 */
Packit ae235b
static const char *ok_100_encode_strs[] = {
Packit ae235b
  "AA==",
Packit ae235b
  "AAE=",
Packit ae235b
  "AAEC",
Packit ae235b
  "AAECAw==",
Packit ae235b
  "AAECAwQ=",
Packit ae235b
  "AAECAwQF",
Packit ae235b
  "AAECAwQFBg==",
Packit ae235b
  "AAECAwQFBgc=",
Packit ae235b
  "AAECAwQFBgcI",
Packit ae235b
  "AAECAwQFBgcICQ==",
Packit ae235b
  "AAECAwQFBgcICQo=",
Packit ae235b
  "AAECAwQFBgcICQoL",
Packit ae235b
  "AAECAwQFBgcICQoLDA==",
Packit ae235b
  "AAECAwQFBgcICQoLDA0=",
Packit ae235b
  "AAECAwQFBgcICQoLDA0O",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODw==",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxA=",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAR",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREg==",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhM=",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMU",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFQ==",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRY=",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYX",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGA==",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBk=",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBka",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGw==",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxw=",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwd",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHg==",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8=",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8g",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gIQ==",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISI=",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIj",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJA==",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCU=",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUm",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJw==",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJyg=",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygp",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKg==",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKis=",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKiss",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLQ==",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4=",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4v",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMA==",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDE=",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEy",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMw==",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ=",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Ng==",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc=",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OQ==",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo=",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PA==",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0=",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+Pw==",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0A=",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BB",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQg==",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQkM=",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQkNE",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQkNERQ==",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQkNERUY=",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQkNERUZH",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQkNERUZHSA==",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQkNERUZHSEk=",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQkNERUZHSElK",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQkNERUZHSElKSw==",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQkNERUZHSElKS0w=",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQkNERUZHSElKS0xN",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQkNERUZHSElKS0xNTg==",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQkNERUZHSElKS0xNTk8=",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQkNERUZHSElKS0xNTk9Q",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQkNERUZHSElKS0xNTk9QUQ==",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQkNERUZHSElKS0xNTk9QUVI=",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQkNERUZHSElKS0xNTk9QUVJT",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQkNERUZHSElKS0xNTk9QUVJTVA==",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQkNERUZHSElKS0xNTk9QUVJTVFU=",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQkNERUZHSElKS0xNTk9QUVJTVFVW",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQkNERUZHSElKS0xNTk9QUVJTVFVWVw==",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQkNERUZHSElKS0xNTk9QUVJTVFVWV1g=",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQkNERUZHSElKS0xNTk9QUVJTVFVWV1hZ",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQkNERUZHSElKS0xNTk9QUVJTVFVWV1hZWg==",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQkNERUZHSElKS0xNTk9QUVJTVFVWV1hZWls=",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQkNERUZHSElKS0xNTk9QUVJTVFVWV1hZWltc",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQkNERUZHSElKS0xNTk9QUVJTVFVWV1hZWltcXQ==",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQkNERUZHSElKS0xNTk9QUVJTVFVWV1hZWltcXV4=",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQkNERUZHSElKS0xNTk9QUVJTVFVWV1hZWltcXV5f",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQkNERUZHSElKS0xNTk9QUVJTVFVWV1hZWltcXV5fYA==",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQkNERUZHSElKS0xNTk9QUVJTVFVWV1hZWltcXV5fYGE=",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQkNERUZHSElKS0xNTk9QUVJTVFVWV1hZWltcXV5fYGFi",
Packit ae235b
  "AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQkNERUZHSElKS0xNTk9QUVJTVFVWV1hZWltcXV5fYGFiYw==",
Packit ae235b
  NULL
Packit ae235b
};
Packit ae235b
Packit ae235b
static void
Packit ae235b
generate_databuffer_for_base64 (struct MyRawData *p)
Packit ae235b
{
Packit ae235b
  int i;
Packit ae235b
  for (i = 0; i < DATA_SIZE; i++)
Packit ae235b
    p->data[i] = i;
Packit ae235b
}
Packit ae235b
Packit ae235b
static void
Packit ae235b
test_base64_encode (void)
Packit ae235b
{
Packit ae235b
  int i;
Packit ae235b
  gint length = 1;
Packit ae235b
  char *text;
Packit ae235b
  struct MyRawData myraw;
Packit ae235b
Packit ae235b
  generate_databuffer_for_base64 (&myraw);
Packit ae235b
Packit ae235b
  for (i = 0; ok_100_encode_strs[i]; i++)
Packit ae235b
    {
Packit ae235b
      length = i + 1;
Packit ae235b
      text = g_base64_encode (myraw.data, length);
Packit ae235b
      g_assert_cmpstr (text, ==, ok_100_encode_strs[i]);
Packit ae235b
      /* printf ("\"%s\",\n",text); */
Packit ae235b
      g_free (text);
Packit ae235b
    }
Packit ae235b
}
Packit ae235b
Packit ae235b
/* Test that incremental and all-in-one encoding of strings of a length which
Packit ae235b
 * is not a multiple of 3 bytes behave the same, as the state carried over
Packit ae235b
 * between g_base64_encode_step() calls varies depending on how the input is
Packit ae235b
 * split up. This is like the test_base64_decode_smallblock() test, but for
Packit ae235b
 * encoding. */
Packit ae235b
static void
Packit ae235b
test_base64_encode_incremental_small_block (gconstpointer block_size_p)
Packit ae235b
{
Packit ae235b
  gsize i;
Packit ae235b
  struct MyRawData myraw;
Packit ae235b
Packit ae235b
  g_test_bug ("780066");
Packit ae235b
Packit ae235b
  generate_databuffer_for_base64 (&myraw);
Packit ae235b
Packit ae235b
  for (i = 0; ok_100_encode_strs[i] != NULL; i++)
Packit ae235b
    {
Packit ae235b
      const guint block_size = GPOINTER_TO_UINT (block_size_p);
Packit ae235b
      gchar *encoded_complete = NULL;
Packit ae235b
      gchar encoded_stepped[1024];
Packit ae235b
      gint state = 0, save = 0;
Packit ae235b
      gsize len_written, len_read, len_to_read, input_length;
Packit ae235b
Packit ae235b
      input_length = i + 1;
Packit ae235b
Packit ae235b
      /* Do it all at once. */
Packit ae235b
      encoded_complete = g_base64_encode (myraw.data, input_length);
Packit ae235b
Packit ae235b
      /* Split the data up so some number of bits remain after each step. */
Packit ae235b
      for (len_written = 0, len_read = 0; len_read < input_length; len_read += len_to_read)
Packit ae235b
        {
Packit ae235b
          len_to_read = MIN (block_size, input_length - len_read);
Packit ae235b
          len_written += g_base64_encode_step (myraw.data + len_read, len_to_read,
Packit ae235b
                                               FALSE,
Packit ae235b
                                               encoded_stepped + len_written,
Packit ae235b
                                               &state, &save);
Packit ae235b
        }
Packit ae235b
Packit ae235b
      len_written += g_base64_encode_close (FALSE, encoded_stepped + len_written,
Packit ae235b
                                            &state, &save);
Packit ae235b
      g_assert_cmpuint (len_written, <, G_N_ELEMENTS (encoded_stepped));
Packit ae235b
Packit ae235b
      /* Nul-terminate to make string comparison easier. */
Packit ae235b
      encoded_stepped[len_written] = '\0';
Packit ae235b
Packit ae235b
      /* Compare results. They should be the same. */
Packit ae235b
      g_assert_cmpstr (encoded_complete, ==, ok_100_encode_strs[i]);
Packit ae235b
      g_assert_cmpstr (encoded_stepped, ==, encoded_complete);
Packit ae235b
Packit ae235b
      g_free (encoded_complete);
Packit ae235b
    }
Packit ae235b
}
Packit ae235b
Packit ae235b
static void
Packit ae235b
decode_and_compare (const gchar            *datap,
Packit ae235b
                    const struct MyRawData *p)
Packit ae235b
{
Packit ae235b
  guchar *data2;
Packit ae235b
  gsize len;
Packit ae235b
Packit ae235b
  data2 = g_base64_decode (datap, &len;;
Packit ae235b
  g_assert_cmpmem (p->data, p->length, data2, len);
Packit ae235b
  g_free (data2);
Packit ae235b
}
Packit ae235b
Packit ae235b
static void
Packit ae235b
decode_inplace_and_compare (const gchar            *datap,
Packit ae235b
                            const struct MyRawData *p)
Packit ae235b
{
Packit ae235b
  gchar *data;
Packit ae235b
  guchar *data2;
Packit ae235b
  gsize len;
Packit ae235b
Packit ae235b
  data = g_strdup (datap);
Packit ae235b
  data2 = g_base64_decode_inplace (data, &len;;
Packit ae235b
  g_assert_cmpmem (p->data, p->length, data2, len);
Packit ae235b
  g_free (data2);
Packit ae235b
}
Packit ae235b
Packit ae235b
static void
Packit ae235b
test_base64_decode (void)
Packit ae235b
{
Packit ae235b
  int i;
Packit ae235b
  struct MyRawData myraw;
Packit ae235b
Packit ae235b
  generate_databuffer_for_base64 (&myraw);
Packit ae235b
Packit ae235b
  for (i = 0; ok_100_encode_strs[i]; i++)
Packit ae235b
    {
Packit ae235b
      myraw.length = i + 1;
Packit ae235b
      decode_and_compare (ok_100_encode_strs[i], &myraw);
Packit ae235b
    }
Packit ae235b
}
Packit ae235b
Packit ae235b
static void
Packit ae235b
test_base64_decode_inplace (void)
Packit ae235b
{
Packit ae235b
  int i;
Packit ae235b
  struct MyRawData myraw;
Packit ae235b
Packit ae235b
  generate_databuffer_for_base64 (&myraw);
Packit ae235b
Packit ae235b
  for (i = 0; ok_100_encode_strs[i]; i++)
Packit ae235b
    {
Packit ae235b
      myraw.length = i + 1;
Packit ae235b
      decode_inplace_and_compare (ok_100_encode_strs[i], &myraw);
Packit ae235b
    }
Packit ae235b
}
Packit ae235b
Packit ae235b
static void
Packit ae235b
test_base64_encode_decode (void)
Packit ae235b
{
Packit ae235b
  int i;
Packit ae235b
  char *text;
Packit ae235b
  struct MyRawData myraw;
Packit ae235b
Packit ae235b
  generate_databuffer_for_base64 (&myraw);
Packit ae235b
Packit ae235b
  for (i = 0; i < DATA_SIZE; i++)
Packit ae235b
    {
Packit ae235b
      myraw.length = i + 1;
Packit ae235b
      text = g_base64_encode (myraw.data, myraw.length);
Packit ae235b
Packit ae235b
      decode_and_compare (text, &myraw);
Packit ae235b
Packit ae235b
      g_free (text);
Packit ae235b
    }
Packit ae235b
}
Packit ae235b
Packit ae235b
static void
Packit ae235b
test_base64_decode_smallblock (gconstpointer blocksize_p)
Packit ae235b
{
Packit ae235b
  const guint blocksize = GPOINTER_TO_UINT (blocksize_p);
Packit ae235b
  guint i;
Packit ae235b
Packit ae235b
  for (i = 0; ok_100_encode_strs[i]; i++)
Packit ae235b
    {
Packit ae235b
      const char *str = ok_100_encode_strs[i];
Packit ae235b
      const char *p;
Packit ae235b
      gsize len = strlen (str);
Packit ae235b
      gint state = 0;
Packit ae235b
      guint save = 0;
Packit ae235b
      guchar *decoded;
Packit ae235b
      gsize decoded_size = 0;
Packit ae235b
      guchar *decoded_atonce;
Packit ae235b
      gsize decoded_atonce_size = 0;
Packit ae235b
Packit ae235b
      decoded = g_malloc (len / 4 * 3 + 3);
Packit ae235b
Packit ae235b
      p = str;
Packit ae235b
      while (len > 0)
Packit ae235b
        {
Packit ae235b
          int chunk_len = MIN (blocksize, len);
Packit ae235b
          gsize size = g_base64_decode_step (p, chunk_len,
Packit ae235b
                                             decoded + decoded_size,
Packit ae235b
                                             &state, &save);
Packit ae235b
          decoded_size += size;
Packit ae235b
          len -= chunk_len;
Packit ae235b
          p += chunk_len;
Packit ae235b
        }
Packit ae235b
Packit ae235b
      decoded_atonce = g_base64_decode (str, &decoded_atonce_size);
Packit ae235b
Packit ae235b
      g_assert_cmpmem (decoded, decoded_size, decoded_atonce, decoded_atonce_size);
Packit ae235b
      
Packit ae235b
      g_free (decoded);
Packit ae235b
      g_free (decoded_atonce);
Packit ae235b
    }
Packit ae235b
}
Packit ae235b
Packit ae235b
Packit ae235b
int
Packit ae235b
main (int argc, char *argv[])
Packit ae235b
{
Packit ae235b
  gint i;
Packit ae235b
Packit ae235b
  g_test_init (&argc, &argv, NULL);
Packit ae235b
  g_test_bug_base ("https://bugzilla.gnome.org/browse.cgi?product=");
Packit ae235b
Packit ae235b
  for (i = 0; i < DATA_SIZE; i++)
Packit ae235b
    data[i] = (guchar)i;
Packit ae235b
Packit ae235b
  g_test_add_data_func ("/base64/full/1", GINT_TO_POINTER (DATA_SIZE), test_full);
Packit ae235b
  g_test_add_data_func ("/base64/full/2", GINT_TO_POINTER (1), test_full);
Packit ae235b
  g_test_add_data_func ("/base64/full/3", GINT_TO_POINTER (2), test_full);
Packit ae235b
  g_test_add_data_func ("/base64/full/4", GINT_TO_POINTER (3), test_full);
Packit ae235b
Packit ae235b
  g_test_add_data_func ("/base64/encode/incremental/small-block/1", GINT_TO_POINTER (1), test_base64_encode_incremental_small_block);
Packit ae235b
  g_test_add_data_func ("/base64/encode/incremental/small-block/2", GINT_TO_POINTER (2), test_base64_encode_incremental_small_block);
Packit ae235b
  g_test_add_data_func ("/base64/encode/incremental/small-block/3", GINT_TO_POINTER (3), test_base64_encode_incremental_small_block);
Packit ae235b
  g_test_add_data_func ("/base64/encode/incremental/small-block/4", GINT_TO_POINTER (4), test_base64_encode_incremental_small_block);
Packit ae235b
Packit ae235b
  g_test_add_data_func ("/base64/incremental/nobreak/1", GINT_TO_POINTER (DATA_SIZE), test_incremental_nobreak);
Packit ae235b
  g_test_add_data_func ("/base64/incremental/break/1", GINT_TO_POINTER (DATA_SIZE), test_incremental_break);
Packit ae235b
Packit ae235b
  g_test_add_data_func ("/base64/incremental/nobreak/2", GINT_TO_POINTER (DATA_SIZE - 1), test_incremental_nobreak);
Packit ae235b
  g_test_add_data_func ("/base64/incremental/break/2", GINT_TO_POINTER (DATA_SIZE - 1), test_incremental_break);
Packit ae235b
Packit ae235b
  g_test_add_data_func ("/base64/incremental/nobreak/3", GINT_TO_POINTER (DATA_SIZE - 2), test_incremental_nobreak);
Packit ae235b
  g_test_add_data_func ("/base64/incremental/break/3", GINT_TO_POINTER (DATA_SIZE - 2), test_incremental_break);
Packit ae235b
Packit ae235b
  g_test_add_data_func ("/base64/incremental/nobreak/4-a", GINT_TO_POINTER (1), test_incremental_nobreak);
Packit ae235b
  g_test_add_data_func ("/base64/incremental/nobreak/4-b", GINT_TO_POINTER (2), test_incremental_nobreak);
Packit ae235b
  g_test_add_data_func ("/base64/incremental/nobreak/4-c", GINT_TO_POINTER (3), test_incremental_nobreak);
Packit ae235b
Packit ae235b
  g_test_add_func ("/base64/encode", test_base64_encode);
Packit ae235b
  g_test_add_func ("/base64/decode", test_base64_decode);
Packit ae235b
  g_test_add_func ("/base64/decode-inplace", test_base64_decode_inplace);
Packit ae235b
  g_test_add_func ("/base64/encode-decode", test_base64_encode_decode);
Packit ae235b
Packit ae235b
  g_test_add_data_func ("/base64/incremental/smallblock/1", GINT_TO_POINTER(1),
Packit ae235b
                        test_base64_decode_smallblock);
Packit ae235b
  g_test_add_data_func ("/base64/incremental/smallblock/2", GINT_TO_POINTER(2),
Packit ae235b
                        test_base64_decode_smallblock);
Packit ae235b
  g_test_add_data_func ("/base64/incremental/smallblock/3", GINT_TO_POINTER(3),
Packit ae235b
                        test_base64_decode_smallblock);
Packit ae235b
  g_test_add_data_func ("/base64/incremental/smallblock/4", GINT_TO_POINTER(4),
Packit ae235b
                        test_base64_decode_smallblock);
Packit ae235b
Packit ae235b
  return g_test_run ();
Packit ae235b
}