Add a test for glyph extents

This verifies a recent fix for COLRv1 returning
0,0,-1,1 for extents of non-painting glyphs.
diff --git a/test/api/Makefile.am b/test/api/Makefile.am
index 7d738c6..c021eca 100644
--- a/test/api/Makefile.am
+++ b/test/api/Makefile.am
@@ -42,6 +42,7 @@
 	test-cplusplus \
 	test-common \
 	test-draw \
+	test-extents \
 	test-font \
 	test-font-scale \
 	test-instance-cff2 \
diff --git a/test/api/fonts/adwaita.ttf b/test/api/fonts/adwaita.ttf
new file mode 100644
index 0000000..6415611
--- /dev/null
+++ b/test/api/fonts/adwaita.ttf
Binary files differ
diff --git a/test/api/meson.build b/test/api/meson.build
index a128e64..dd23fc7 100644
--- a/test/api/meson.build
+++ b/test/api/meson.build
@@ -15,6 +15,7 @@
   'test-cplusplus.cc',
   'test-common.c',
   'test-draw.c',
+  'test-extents.c',
   'test-font.c',
   'test-font-scale.c',
   'test-instance-cff2.c',
diff --git a/test/api/test-extents.c b/test/api/test-extents.c
new file mode 100644
index 0000000..8600751
--- /dev/null
+++ b/test/api/test-extents.c
@@ -0,0 +1,104 @@
+/*
+ * Copyright © 2023 Red Hat, Inc.
+ *
+ *  This is part of HarfBuzz, a text shaping library.
+ *
+ * Permission is hereby granted, without written agreement and without
+ * license or royalty fees, to use, copy, modify, and distribute this
+ * software and its documentation for any purpose, provided that the
+ * above copyright notice and the following two paragraphs appear in
+ * all copies of this software.
+ *
+ * IN NO EVENT SHALL THE COPYRIGHT HOLDER BE LIABLE TO ANY PARTY FOR
+ * DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES
+ * ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN
+ * IF THE COPYRIGHT HOLDER HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
+ * DAMAGE.
+ *
+ * THE COPYRIGHT HOLDER SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING,
+ * BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
+ * FITNESS FOR A PARTICULAR PURPOSE.  THE SOFTWARE PROVIDED HEREUNDER IS
+ * ON AN "AS IS" BASIS, AND THE COPYRIGHT HOLDER HAS NO OBLIGATION TO
+ * PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
+ *
+ * Author(s): Matthias Clasen
+ */
+
+#include "hb-test.h"
+
+
+static void
+test_glyph_extents (void)
+{
+  hb_face_t *face;
+  hb_font_t *font;
+  hb_glyph_extents_t extents;
+  hb_bool_t ret;
+
+  /* This font contains a COLRv1 glyph with a ClipBox,
+   * and various components without. The main thing
+   * we test here is that glyphs with no paint return
+   * 0,0,0,0 and not meaningless numbers.
+   */
+
+  face = hb_test_open_font_file ("fonts/adwaita.ttf");
+  font = hb_font_create (face);
+
+  ret = hb_font_get_glyph_extents (font, 0, &extents);
+  g_assert_true (ret);
+  g_assert_true (extents.x_bearing == 0 &&
+                 extents.y_bearing == 0 &&
+                 extents.width     == 0 &&
+                 extents.height    == 0);
+
+  ret = hb_font_get_glyph_extents (font, 1, &extents);
+  g_assert_true (ret);
+  g_assert_true (extents.x_bearing == 0 &&
+                 extents.y_bearing == 0 &&
+                 extents.width     == 0 &&
+                 extents.height    == 0);
+
+  ret = hb_font_get_glyph_extents (font, 2, &extents);
+  g_assert_true (ret);
+  g_assert_true (extents.x_bearing ==   180 &&
+                 extents.y_bearing ==   960 &&
+                 extents.width     ==  1060 &&
+                 extents.height    == -1220);
+
+  ret = hb_font_get_glyph_extents (font, 3, &extents);
+  g_assert_true (ret);
+  g_assert_true (extents.x_bearing ==   188 &&
+                 extents.y_bearing ==   950 &&
+                 extents.width     ==   900 &&
+                 extents.height    == -1200);
+
+  ret = hb_font_get_glyph_extents (font, 4, &extents);
+  g_assert_true (ret);
+  g_assert_true (extents.x_bearing ==   413 &&
+                 extents.y_bearing ==    50 &&
+                 extents.width     ==   150 &&
+                 extents.height    ==   -75);
+
+  ret = hb_font_get_glyph_extents (font, 5, &extents);
+  g_assert_true (ret);
+  g_assert_true (extents.x_bearing ==   638 &&
+                 extents.y_bearing ==   350 &&
+                 extents.width     ==   600 &&
+                 extents.height    ==  -600);
+
+  ret = hb_font_get_glyph_extents (font, 1000, &extents);
+  g_assert_false (ret);
+
+  hb_font_destroy (font);
+  hb_face_destroy (face);
+}
+
+int
+main (int argc, char **argv)
+{
+  hb_test_init (&argc, &argv);
+
+  hb_test_add (test_glyph_extents);
+
+  return hb_test_run();
+}