// ---------------------------------------------------------------------- // File: XrdCpAbort.cc // Author: Andreas-Joachim Peters - CERN // ---------------------------------------------------------------------- /************************************************************************ * EOS - the CERN Disk Storage System * * Copyright (C) 2011 CERN/Switzerland * * * * This program is free software: you can redistribute it and/or modify * * it under the terms of the GNU General Public License as published by * * the Free Software Foundation, either version 3 of the License, or * * (at your option) any later version. * * * * This program is distributed in the hope that it will be useful, * * but WITHOUT ANY WARRANTY; without even the implied warranty of * * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * * GNU General Public License for more details. * * * * You should have received a copy of the GNU General Public License * * along with this program. If not, see .* ************************************************************************/ /*-----------------------------------------------------------------------------*/ /*-----------------------------------------------------------------------------*/ #include #include #include #include /*-----------------------------------------------------------------------------*/ #include #include #include /*-----------------------------------------------------------------------------*/ XrdPosixXrootd posixXrootd; int main (int argc, char* argv[]) { // create a 1k file but does not close it! XrdOucString urlFile = argv[1]; if (!urlFile.length()) { fprintf(stderr,"usage: xrdcpabort \n"); exit(EINVAL); } int fdWrite = XrdPosixXrootd::Open(urlFile.c_str(), O_CREAT|O_RDWR|O_TRUNC, kXR_ur | kXR_uw | kXR_gw | kXR_gr | kXR_or ); off_t offset = 0; size_t sizeHeader = 4* 1024; size_t sizeBuffer = 1024*1024; char* buffer = (char*)malloc(sizeBuffer); if (!buffer) exit(-1); std::ifstream urandom("/dev/urandom", std::ios::in | std::ios::binary); urandom.read(buffer, sizeBuffer); urandom.close(); if (fdWrite >= 0) { offset = 0; XrdPosixXrootd::Pwrite(fdWrite, buffer, sizeHeader, offset); XrdPosixXrootd::Ftruncate(fdWrite, sizeBuffer * 4 + sizeHeader); offset = sizeHeader; XrdPosixXrootd::Pwrite(fdWrite, buffer, sizeBuffer, offset); XrdPosixXrootd::Ftruncate(fdWrite, sizeBuffer * 4 + sizeHeader); offset = sizeHeader + sizeBuffer; XrdPosixXrootd::Pwrite(fdWrite, buffer, sizeBuffer, offset); XrdPosixXrootd::Ftruncate(fdWrite, sizeBuffer * 4 + sizeHeader); offset = sizeHeader + 2 * sizeBuffer; XrdPosixXrootd::Pwrite(fdWrite, buffer, sizeBuffer, offset); XrdPosixXrootd::Ftruncate(fdWrite, sizeBuffer * 4 + sizeHeader); offset = sizeHeader + 3 * sizeBuffer; XrdPosixXrootd::Pwrite(fdWrite, buffer, sizeBuffer, offset); XrdPosixXrootd::Ftruncate(fdWrite, sizeBuffer * 8 + sizeHeader); offset = sizeHeader + 4 * sizeBuffer; XrdPosixXrootd::Pwrite(fdWrite, buffer, 250*1024, offset); XrdPosixXrootd::Ftruncate(fdWrite, sizeBuffer * 8 + sizeHeader); XrdPosixXrootd::Close(fdWrite); exit(0); } else { exit(-1); } }