1
0
mirror of git://sourceware.org/git/lvm2.git synced 2024-12-21 13:34:40 +03:00

test: Use append for journal maintenance instead of rename.

This commit is contained in:
Petr Rockai 2014-06-28 11:15:13 +02:00
parent 23b5a006d4
commit b3caba849d
2 changed files with 22 additions and 18 deletions

View File

@ -61,9 +61,21 @@ struct Journal {
}
typedef std::map< std::string, R > Status;
Status status;
Status status, written;
std::string location_tmp, location;
std::string location, list;
void append( std::string path ) {
std::ofstream of( path.c_str(), std::fstream::app );
Status::iterator writ;
for ( Status::iterator i = status.begin(); i != status.end(); ++i ) {
writ = written.find( i->first );
if ( writ == written.end() || writ->second != i->second )
of << i->first << " " << i->second << std::endl;
}
written = status;
of.close();
}
void write( std::string path ) {
std::ofstream of( path.c_str() );
@ -73,9 +85,10 @@ struct Journal {
}
void sync() {
write( location_tmp );
fsync_name( location_tmp );
rename( location_tmp.c_str(), location.c_str() );
append( location );
fsync_name( location );
write ( list );
fsync_name( list );
}
void started( std::string n ) {
@ -122,20 +135,11 @@ struct Journal {
std::copy( It( ifs ), It(), std::inserter( status, status.begin() ) );
}
void read() {
struct stat64 stat;
if ( ::stat64( location.c_str(), &stat ) == 0 )
read( location );
/* on CIFS, rename might fail halfway through, with journal
* already gone but journal.tmp not yet replacing it... in that
* case, pick up journal.tmp */
else if ( ::stat64( location_tmp.c_str(), &stat ) == 0 )
read( location_tmp );
}
void read() { read( location ); }
Journal( std::string dir )
: location( dir + "/journal" ),
location_tmp( dir + "/journal.tmp" )
list( dir + "/list" )
{}
};

View File

@ -382,6 +382,8 @@ struct Main {
if ( options.cont )
journal.read();
else
::unlink( journal.location.c_str() );
}
void run() {
@ -406,8 +408,6 @@ struct Main {
}
journal.banner();
journal.write( options.outdir + "/list" );
fsync_name( options.outdir + "/list" );
if ( die || fatal_signal )
exit( 1 );
}