/*
 * this tests that chain-based pads don't pull.
 */

#include <gst/gst.h>

typedef struct _GstTestSink
{
  GstElement parent;
  GstPad *sinkpad;
} GstTestSink;

typedef GstElementClass GstTestSinkClass;

static void
gst_test_sink_class_init (GstTestSinkClass * klass)
{
}

static void
gst_test_sink_base_init (gpointer klass)
{
}

static void
gst_test_sink_chain (GstPad * pad, GstData * data)
{
  data = gst_pad_pull (pad);
}

static void
gst_test_sink_init (GstTestSink * sink)
{
  sink->sinkpad = gst_pad_new ("sink", GST_PAD_SINK);
  gst_pad_set_chain_function (sink->sinkpad, gst_test_sink_chain);
  gst_element_add_pad (GST_ELEMENT (sink), sink->sinkpad);
}

GST_BOILERPLATE (GstTestSink, gst_test_sink, GstElement, GST_TYPE_ELEMENT);

int
main (int argc, char *argv[])
{
  GstElement *pipeline, *fakesrc, *testsink;
  gint n;

  gst_init (&argc, &argv);

  pipeline = gst_pipeline_new ("p");
  fakesrc = gst_element_factory_make ("fakesrc", "src");
  testsink = g_object_new (gst_test_sink_get_type (), NULL);
  gst_object_set_name (GST_OBJECT (testsink), "sink");
  gst_bin_add_many (GST_BIN (pipeline), fakesrc, testsink, NULL);
  gst_element_link (fakesrc, testsink);
  gst_element_set_state (pipeline, GST_STATE_PLAYING);

  for (n = 0; n < 100; n++) {
    if (!gst_bin_iterate (GST_BIN (pipeline)))
      break;
  }

  gst_element_set_state (pipeline, GST_STATE_NULL);
  gst_object_unref (pipeline);

  return 0;
}