Mercurial > hg > monetdb-java
view tests/Test_Cforkbomb.java @ 693:3442d331cad0
In test_ServerStopsReading, wait longer for the server to cancel the upload
Some recent server versions perform more readahead in COPY INTO.
This means that a query such as
COPY 10 RECORDS INTO foo FROM 'some-file' ON CLIENT
will upload much more data before the server finally decides it can
cancel the rest of the upload. When testing the cancellation
behavior we need to take this into account.
author | Joeri van Ruth <joeri.van.ruth@monetdbsolutions.com> |
---|---|
date | Mon, 21 Nov 2022 15:59:49 +0100 (2022-11-21) |
parents | 6aa38e8c0f2d |
children | aeb268156580 |
line wrap: on
line source
/* * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. * * Copyright 1997 - July 2008 CWI, August 2008 - 2022 MonetDB B.V. */ import java.sql.*; import java.util.*; public class Test_Cforkbomb { private static String args[]; static class Worker extends Thread { private int id; public Worker(int id) { this.id = id; } public void run() { try { System.out.print("Establishing Connection " + id + "..."); Connection con = DriverManager.getConnection(args[0]); System.out.println(" done..."); // do something with the connection to test if it works Statement stmt = con.createStatement(); ResultSet rs = stmt.executeQuery("SELECT " + id); if (!rs.next()) { System.out.println("thread " + id + " got no response from server :("); } else { if (rs.getInt(1) == id) { System.out.println("thread " + id + ": connection ok"); } else { System.out.println("thread " + id + ": got garbage: " + rs.getString(1)); } } con.close(); } catch (SQLException e) { System.out.println("thread " + id + " unhappy: " + e.toString()); } } } public static void main(String[] args) throws Exception { Test_Cforkbomb.args = args; // just DoS the server full throttle :) int i; for (i = 0; i < 200; i++) { Worker w = new Worker(i); w.start(); } } }