2016-12-16 23:57:33 +03:00
|
|
|
/*
|
2019-06-20 02:58:25 +03:00
|
|
|
* Copyright (c) Facebook, Inc. and its affiliates.
|
2016-12-16 23:57:33 +03:00
|
|
|
*
|
2019-06-20 02:58:25 +03:00
|
|
|
* This software may be used and distributed according to the terms of the
|
|
|
|
* GNU General Public License version 2.
|
2016-12-16 23:57:33 +03:00
|
|
|
*/
|
2019-10-11 15:26:59 +03:00
|
|
|
|
2016-12-16 23:57:33 +03:00
|
|
|
#include "TestUtil.h"
|
|
|
|
|
|
|
|
#include <cstring>
|
|
|
|
#include <stdexcept>
|
|
|
|
#include "eden/fs/model/Hash.h"
|
|
|
|
|
|
|
|
namespace facebook {
|
|
|
|
namespace eden {
|
|
|
|
Hash makeTestHash(folly::StringPiece value) {
|
|
|
|
constexpr size_t ASCII_SIZE = 2 * Hash::RAW_SIZE;
|
|
|
|
if (value.size() > ASCII_SIZE) {
|
|
|
|
throw std::invalid_argument(value.toString() + " is too big for Hash");
|
|
|
|
}
|
|
|
|
std::array<char, ASCII_SIZE> fullValue;
|
|
|
|
memset(fullValue.data(), '0', fullValue.size());
|
|
|
|
memcpy(
|
|
|
|
fullValue.data() + fullValue.size() - value.size(),
|
|
|
|
value.data(),
|
|
|
|
value.size());
|
|
|
|
return Hash{folly::StringPiece{folly::range(fullValue)}};
|
|
|
|
}
|
2017-11-04 01:58:04 +03:00
|
|
|
} // namespace eden
|
|
|
|
} // namespace facebook
|