dc5e0b120a
As @dtzWill discovered, with the concurrent hydra-evaluator, there can be multiple active transactions adding builds to the database. As a result, builds can become visible in a non-monotonically increasing order, breaking the queue monitor's assumption that build IDs only go up. The fix is to have hydra-eval-jobset provide the lowest build ID it just added in the builds_added notification, and have the queue monitor check from there. Fixes #496.
44 lines
1 KiB
C++
44 lines
1 KiB
C++
#pragma once
|
|
|
|
#include <pqxx/pqxx>
|
|
|
|
#include "util.hh"
|
|
|
|
|
|
struct Connection : pqxx::connection
|
|
{
|
|
Connection() : pqxx::connection(getFlags()) { };
|
|
|
|
std::string getFlags()
|
|
{
|
|
using namespace nix;
|
|
auto s = getEnv("HYDRA_DBI", "dbi:Pg:dbname=hydra;");
|
|
std::string prefix = "dbi:Pg:";
|
|
if (std::string(s, 0, prefix.size()) != prefix)
|
|
throw Error("$HYDRA_DBI does not denote a PostgreSQL database");
|
|
return concatStringsSep(" ", tokenizeString<Strings>(string(s, prefix.size()), ";"));
|
|
}
|
|
};
|
|
|
|
|
|
class receiver : public pqxx::notification_receiver
|
|
{
|
|
std::experimental::optional<std::string> status;
|
|
|
|
public:
|
|
|
|
receiver(pqxx::connection_base & c, const std::string & channel)
|
|
: pqxx::notification_receiver(c, channel) { }
|
|
|
|
void operator() (const std::string & payload, int pid) override
|
|
{
|
|
status = payload;
|
|
};
|
|
|
|
std::experimental::optional<std::string> get() {
|
|
auto s = status;
|
|
status = std::experimental::nullopt;
|
|
return s;
|
|
}
|
|
};
|