Add tests for COPY in PL/pgSQL

This stresses the error handling of COPY inside SPI which does not
support the operation using stdin or stdout, and these scenarios were
not tested up to now.

Author: Mark Dilger
Discussion: https://postgr.es/m/a6e9b130-7fd5-387b-4ec5-89bda24373ab@gmail.com
pull/161/head
Michael Paquier 6 years ago
parent aae50236e4
commit 1858b105b0
  1. 4
      src/pl/plpgsql/src/Makefile
  2. 3
      src/pl/plpgsql/src/data/copy1.data
  3. 1
      src/pl/plpgsql/src/expected/.gitignore
  4. 62
      src/pl/plpgsql/src/input/plpgsql_copy.source
  5. 89
      src/pl/plpgsql/src/output/plpgsql_copy.source
  6. 1
      src/pl/plpgsql/src/sql/.gitignore

@ -32,8 +32,8 @@ DATA = plpgsql.control plpgsql--1.0.sql plpgsql--unpackaged--1.0.sql
REGRESS_OPTS = --dbname=$(PL_TESTDB)
REGRESS = plpgsql_call plpgsql_control plpgsql_domain plpgsql_record \
plpgsql_cache plpgsql_transaction plpgsql_trap \
REGRESS = plpgsql_call plpgsql_control plpgsql_copy plpgsql_domain \
plpgsql_record plpgsql_cache plpgsql_transaction plpgsql_trap \
plpgsql_trigger plpgsql_varprops
# where to find gen_keywordlist.pl and subsidiary files

@ -0,0 +1,3 @@
1 1.1
2 2.2
3 3.3

@ -0,0 +1 @@
/plpgsql_copy.out

@ -0,0 +1,62 @@
CREATE TABLE copy1 (a int, b float);
-- COPY TO/FROM not authorized from client.
DO LANGUAGE plpgsql $$
BEGIN
COPY copy1 TO stdout;
END;
$$;
DO LANGUAGE plpgsql $$
BEGIN
COPY copy1 FROM stdin;
END;
$$;
DO LANGUAGE plpgsql $$
BEGIN
EXECUTE 'COPY copy1 TO stdout';
END;
$$;
DO LANGUAGE plpgsql $$
BEGIN
EXECUTE 'COPY copy1 FROM stdin';
END;
$$;
-- Valid cases
-- COPY FROM
DO LANGUAGE plpgsql $$
BEGIN
COPY copy1 FROM '@abs_srcdir@/data/copy1.data';
END;
$$;
SELECT * FROM copy1 ORDER BY 1;
TRUNCATE copy1;
DO LANGUAGE plpgsql $$
BEGIN
EXECUTE 'COPY copy1 FROM ''@abs_srcdir@/data/copy1.data''';
END;
$$;
SELECT * FROM copy1 ORDER BY 1;
-- COPY TO
-- Copy the data externally once, then process it back to the table.
DO LANGUAGE plpgsql $$
BEGIN
COPY copy1 TO '@abs_builddir@/results/copy1.data';
END;
$$;
TRUNCATE copy1;
DO LANGUAGE plpgsql $$
BEGIN
COPY copy1 FROM '@abs_builddir@/results/copy1.data';
END;
$$;
DO LANGUAGE plpgsql $$
BEGIN
EXECUTE 'COPY copy1 FROM ''@abs_builddir@/results/copy1.data''';
END;
$$;
SELECT * FROM copy1 ORDER BY 1;
DROP TABLE copy1;

@ -0,0 +1,89 @@
CREATE TABLE copy1 (a int, b float);
-- COPY TO/FROM not authorized from client.
DO LANGUAGE plpgsql $$
BEGIN
COPY copy1 TO stdout;
END;
$$;
ERROR: cannot COPY to/from client in PL/pgSQL
CONTEXT: PL/pgSQL function inline_code_block line 3 at SQL statement
DO LANGUAGE plpgsql $$
BEGIN
COPY copy1 FROM stdin;
END;
$$;
ERROR: cannot COPY to/from client in PL/pgSQL
CONTEXT: PL/pgSQL function inline_code_block line 3 at SQL statement
DO LANGUAGE plpgsql $$
BEGIN
EXECUTE 'COPY copy1 TO stdout';
END;
$$;
ERROR: cannot COPY to/from client in PL/pgSQL
CONTEXT: PL/pgSQL function inline_code_block line 3 at EXECUTE
DO LANGUAGE plpgsql $$
BEGIN
EXECUTE 'COPY copy1 FROM stdin';
END;
$$;
ERROR: cannot COPY to/from client in PL/pgSQL
CONTEXT: PL/pgSQL function inline_code_block line 3 at EXECUTE
-- Valid cases
-- COPY FROM
DO LANGUAGE plpgsql $$
BEGIN
COPY copy1 FROM '@abs_builddir@/data/copy1.data';
END;
$$;
SELECT * FROM copy1 ORDER BY 1;
a | b
---+-----
1 | 1.1
2 | 2.2
3 | 3.3
(3 rows)
TRUNCATE copy1;
DO LANGUAGE plpgsql $$
BEGIN
EXECUTE 'COPY copy1 FROM ''@abs_builddir@/data/copy1.data''';
END;
$$;
SELECT * FROM copy1 ORDER BY 1;
a | b
---+-----
1 | 1.1
2 | 2.2
3 | 3.3
(3 rows)
-- COPY TO
-- Copy the data externally once, then process it back to the table.
DO LANGUAGE plpgsql $$
BEGIN
COPY copy1 TO '@abs_builddir@/results/copy1.data';
END;
$$;
TRUNCATE copy1;
DO LANGUAGE plpgsql $$
BEGIN
COPY copy1 FROM '@abs_builddir@/results/copy1.data';
END;
$$;
DO LANGUAGE plpgsql $$
BEGIN
EXECUTE 'COPY copy1 FROM ''@abs_builddir@/results/copy1.data''';
END;
$$;
SELECT * FROM copy1 ORDER BY 1;
a | b
---+-----
1 | 1.1
1 | 1.1
2 | 2.2
2 | 2.2
3 | 3.3
3 | 3.3
(6 rows)
DROP TABLE copy1;

@ -0,0 +1 @@
/plpgsql_copy.sql
Loading…
Cancel
Save