add tests for constructors with copy control and assign()
authorJosh Coalson <jcoalson@users.sourceforce.net>
Fri, 21 Jan 2005 01:26:36 +0000 (01:26 +0000)
committerJosh Coalson <jcoalson@users.sourceforce.net>
Fri, 21 Jan 2005 01:26:36 +0000 (01:26 +0000)
src/test_libFLAC++/metadata_object.cpp

index 9298c5aa90fdbe22d1b24ea4c95dea337edb95c0..22d6427cff7018c70d44fc6f1203aed1a933ad8b 100644 (file)
@@ -254,6 +254,54 @@ bool test_metadata_object_streaminfo()
                printf("OK\n");
        }
 
+       printf("testing StreamInfo::StreamInfo(const ::FLAC__StreamMetadata *, copy=true)... +\n");
+       printf("        StreamInfo::operator!=(const ::FLAC__StreamMetadata *)... ");
+       {
+               FLAC::Metadata::StreamInfo blockcopy(&streaminfo_, /*copy=*/true);
+               if(!blockcopy.is_valid())
+                       return die_("!block.is_valid()");
+               if(blockcopy != streaminfo_)
+                       return die_("copy is not identical to original");
+               printf("OK\n");
+       }
+
+       printf("testing StreamInfo::StreamInfo(const ::FLAC__StreamMetadata *, copy=false)... +\n");
+       printf("        StreamInfo::operator!=(const ::FLAC__StreamMetadata *)... ");
+       {
+               ::FLAC__StreamMetadata *copy = ::FLAC__metadata_object_clone(&streaminfo_);
+               FLAC::Metadata::StreamInfo blockcopy(copy, /*copy=*/false);
+               if(!blockcopy.is_valid())
+                       return die_("!block.is_valid()");
+               if(blockcopy != streaminfo_)
+                       return die_("copy is not identical to original");
+               printf("OK\n");
+       }
+
+       printf("testing StreamInfo::assign(const ::FLAC__StreamMetadata *, copy=true)... +\n");
+       printf("        StreamInfo::operator!=(const ::FLAC__StreamMetadata *)... ");
+       {
+               FLAC::Metadata::StreamInfo blockcopy;
+               blockcopy.assign(&streaminfo_, /*copy=*/true);
+               if(!blockcopy.is_valid())
+                       return die_("!block.is_valid()");
+               if(blockcopy != streaminfo_)
+                       return die_("copy is not identical to original");
+               printf("OK\n");
+       }
+
+       printf("testing StreamInfo::assign(const ::FLAC__StreamMetadata *, copy=false)... +\n");
+       printf("        StreamInfo::operator!=(const ::FLAC__StreamMetadata *)... ");
+       {
+               ::FLAC__StreamMetadata *copy = ::FLAC__metadata_object_clone(&streaminfo_);
+               FLAC::Metadata::StreamInfo blockcopy;
+               blockcopy.assign(copy, /*copy=*/false);
+               if(!blockcopy.is_valid())
+                       return die_("!block.is_valid()");
+               if(blockcopy != streaminfo_)
+                       return die_("copy is not identical to original");
+               printf("OK\n");
+       }
+
        printf("testing StreamInfo::operator=(const StreamInfo &)... +\n");
        printf("        StreamInfo::operator==(const StreamInfo &)... ");
        {
@@ -439,6 +487,54 @@ bool test_metadata_object_padding()
                printf("OK\n");
        }
 
+       printf("testing Padding::Padding(const ::FLAC__StreamMetadata *, copy=true)... +\n");
+       printf("        Padding::operator!=(const ::FLAC__StreamMetadata *)... ");
+       {
+               FLAC::Metadata::Padding blockcopy(&padding_, /*copy=*/true);
+               if(!blockcopy.is_valid())
+                       return die_("!block.is_valid()");
+               if(blockcopy != padding_)
+                       return die_("copy is not identical to original");
+               printf("OK\n");
+       }
+
+       printf("testing Padding::Padding(const ::FLAC__StreamMetadata *, copy=false)... +\n");
+       printf("        Padding::operator!=(const ::FLAC__StreamMetadata *)... ");
+       {
+               ::FLAC__StreamMetadata *copy = ::FLAC__metadata_object_clone(&padding_);
+               FLAC::Metadata::Padding blockcopy(copy, /*copy=*/false);
+               if(!blockcopy.is_valid())
+                       return die_("!block.is_valid()");
+               if(blockcopy != padding_)
+                       return die_("copy is not identical to original");
+               printf("OK\n");
+       }
+
+       printf("testing Padding::assign(const ::FLAC__StreamMetadata *, copy=true)... +\n");
+       printf("        Padding::operator!=(const ::FLAC__StreamMetadata *)... ");
+       {
+               FLAC::Metadata::Padding blockcopy;
+               blockcopy.assign(&padding_, /*copy=*/true);
+               if(!blockcopy.is_valid())
+                       return die_("!block.is_valid()");
+               if(blockcopy != padding_)
+                       return die_("copy is not identical to original");
+               printf("OK\n");
+       }
+
+       printf("testing Padding::assign(const ::FLAC__StreamMetadata *, copy=false)... +\n");
+       printf("        Padding::operator!=(const ::FLAC__StreamMetadata *)... ");
+       {
+               ::FLAC__StreamMetadata *copy = ::FLAC__metadata_object_clone(&padding_);
+               FLAC::Metadata::Padding blockcopy;
+               blockcopy.assign(copy, /*copy=*/false);
+               if(!blockcopy.is_valid())
+                       return die_("!block.is_valid()");
+               if(blockcopy != padding_)
+                       return die_("copy is not identical to original");
+               printf("OK\n");
+       }
+
        printf("testing Padding::operator=(const Padding &)... +\n");
        printf("        Padding::operator==(const Padding &)... ");
        {
@@ -552,6 +648,54 @@ bool test_metadata_object_application()
                printf("OK\n");
        }
 
+       printf("testing Application::Application(const ::FLAC__StreamMetadata *, copy=true)... +\n");
+       printf("        Application::operator!=(const ::FLAC__StreamMetadata *)... ");
+       {
+               FLAC::Metadata::Application blockcopy(&application_, /*copy=*/true);
+               if(!blockcopy.is_valid())
+                       return die_("!block.is_valid()");
+               if(blockcopy != application_)
+                       return die_("copy is not identical to original");
+               printf("OK\n");
+       }
+
+       printf("testing Application::Application(const ::FLAC__StreamMetadata *, copy=false)... +\n");
+       printf("        Application::operator!=(const ::FLAC__StreamMetadata *)... ");
+       {
+               ::FLAC__StreamMetadata *copy = ::FLAC__metadata_object_clone(&application_);
+               FLAC::Metadata::Application blockcopy(copy, /*copy=*/false);
+               if(!blockcopy.is_valid())
+                       return die_("!block.is_valid()");
+               if(blockcopy != application_)
+                       return die_("copy is not identical to original");
+               printf("OK\n");
+       }
+
+       printf("testing Application::assign(const ::FLAC__StreamMetadata *, copy=true)... +\n");
+       printf("        Application::operator!=(const ::FLAC__StreamMetadata *)... ");
+       {
+               FLAC::Metadata::Application blockcopy;
+               blockcopy.assign(&application_, /*copy=*/true);
+               if(!blockcopy.is_valid())
+                       return die_("!block.is_valid()");
+               if(blockcopy != application_)
+                       return die_("copy is not identical to original");
+               printf("OK\n");
+       }
+
+       printf("testing Application::assign(const ::FLAC__StreamMetadata *, copy=false)... +\n");
+       printf("        Application::operator!=(const ::FLAC__StreamMetadata *)... ");
+       {
+               ::FLAC__StreamMetadata *copy = ::FLAC__metadata_object_clone(&application_);
+               FLAC::Metadata::Application blockcopy;
+               blockcopy.assign(copy, /*copy=*/false);
+               if(!blockcopy.is_valid())
+                       return die_("!block.is_valid()");
+               if(blockcopy != application_)
+                       return die_("copy is not identical to original");
+               printf("OK\n");
+       }
+
        printf("testing Application::operator=(const Application &)... +\n");
        printf("        Application::operator==(const Application &)... ");
        {
@@ -674,6 +818,54 @@ bool test_metadata_object_seektable()
                printf("OK\n");
        }
 
+       printf("testing SeekTable::SeekTable(const ::FLAC__StreamMetadata *, copy=true)... +\n");
+       printf("        SeekTable::operator!=(const ::FLAC__StreamMetadata *)... ");
+       {
+               FLAC::Metadata::SeekTable blockcopy(&seektable_, /*copy=*/true);
+               if(!blockcopy.is_valid())
+                       return die_("!block.is_valid()");
+               if(blockcopy != seektable_)
+                       return die_("copy is not identical to original");
+               printf("OK\n");
+       }
+
+       printf("testing SeekTable::SeekTable(const ::FLAC__StreamMetadata *, copy=false)... +\n");
+       printf("        SeekTable::operator!=(const ::FLAC__StreamMetadata *)... ");
+       {
+               ::FLAC__StreamMetadata *copy = ::FLAC__metadata_object_clone(&seektable_);
+               FLAC::Metadata::SeekTable blockcopy(copy, /*copy=*/false);
+               if(!blockcopy.is_valid())
+                       return die_("!block.is_valid()");
+               if(blockcopy != seektable_)
+                       return die_("copy is not identical to original");
+               printf("OK\n");
+       }
+
+       printf("testing SeekTable::assign(const ::FLAC__StreamMetadata *, copy=true)... +\n");
+       printf("        SeekTable::operator!=(const ::FLAC__StreamMetadata *)... ");
+       {
+               FLAC::Metadata::SeekTable blockcopy;
+               blockcopy.assign(&seektable_, /*copy=*/true);
+               if(!blockcopy.is_valid())
+                       return die_("!block.is_valid()");
+               if(blockcopy != seektable_)
+                       return die_("copy is not identical to original");
+               printf("OK\n");
+       }
+
+       printf("testing SeekTable::assign(const ::FLAC__StreamMetadata *, copy=false)... +\n");
+       printf("        SeekTable::operator!=(const ::FLAC__StreamMetadata *)... ");
+       {
+               ::FLAC__StreamMetadata *copy = ::FLAC__metadata_object_clone(&seektable_);
+               FLAC::Metadata::SeekTable blockcopy;
+               blockcopy.assign(copy, /*copy=*/false);
+               if(!blockcopy.is_valid())
+                       return die_("!block.is_valid()");
+               if(blockcopy != seektable_)
+                       return die_("copy is not identical to original");
+               printf("OK\n");
+       }
+
        printf("testing SeekTable::operator=(const SeekTable &)... +\n");
        printf("        SeekTable::operator==(const SeekTable &)... ");
        {
@@ -979,6 +1171,54 @@ bool test_metadata_object_vorbiscomment()
                printf("OK\n");
        }
 
+       printf("testing VorbisComment::VorbisComment(const ::FLAC__StreamMetadata *, copy=true)... +\n");
+       printf("        VorbisComment::operator!=(const ::FLAC__StreamMetadata *)... ");
+       {
+               FLAC::Metadata::VorbisComment blockcopy(&vorbiscomment_, /*copy=*/true);
+               if(!blockcopy.is_valid())
+                       return die_("!block.is_valid()");
+               if(blockcopy != vorbiscomment_)
+                       return die_("copy is not identical to original");
+               printf("OK\n");
+       }
+
+       printf("testing VorbisComment::VorbisComment(const ::FLAC__StreamMetadata *, copy=false)... +\n");
+       printf("        VorbisComment::operator!=(const ::FLAC__StreamMetadata *)... ");
+       {
+               ::FLAC__StreamMetadata *copy = ::FLAC__metadata_object_clone(&vorbiscomment_);
+               FLAC::Metadata::VorbisComment blockcopy(copy, /*copy=*/false);
+               if(!blockcopy.is_valid())
+                       return die_("!block.is_valid()");
+               if(blockcopy != vorbiscomment_)
+                       return die_("copy is not identical to original");
+               printf("OK\n");
+       }
+
+       printf("testing VorbisComment::assign(const ::FLAC__StreamMetadata *, copy=true)... +\n");
+       printf("        VorbisComment::operator!=(const ::FLAC__StreamMetadata *)... ");
+       {
+               FLAC::Metadata::VorbisComment blockcopy;
+               blockcopy.assign(&vorbiscomment_, /*copy=*/true);
+               if(!blockcopy.is_valid())
+                       return die_("!block.is_valid()");
+               if(blockcopy != vorbiscomment_)
+                       return die_("copy is not identical to original");
+               printf("OK\n");
+       }
+
+       printf("testing VorbisComment::assign(const ::FLAC__StreamMetadata *, copy=false)... +\n");
+       printf("        VorbisComment::operator!=(const ::FLAC__StreamMetadata *)... ");
+       {
+               ::FLAC__StreamMetadata *copy = ::FLAC__metadata_object_clone(&vorbiscomment_);
+               FLAC::Metadata::VorbisComment blockcopy;
+               blockcopy.assign(copy, /*copy=*/false);
+               if(!blockcopy.is_valid())
+                       return die_("!block.is_valid()");
+               if(blockcopy != vorbiscomment_)
+                       return die_("copy is not identical to original");
+               printf("OK\n");
+       }
+
        printf("testing VorbisComment::operator=(const VorbisComment &)... +\n");
        printf("        VorbisComment::operator==(const VorbisComment &)... ");
        {
@@ -1309,6 +1549,54 @@ bool test_metadata_object_cuesheet()
                printf("OK\n");
        }
 
+       printf("testing CueSheet::CueSheet(const ::FLAC__StreamMetadata *, copy=true)... +\n");
+       printf("        CueSheet::operator!=(const ::FLAC__StreamMetadata *)... ");
+       {
+               FLAC::Metadata::CueSheet blockcopy(&cuesheet_, /*copy=*/true);
+               if(!blockcopy.is_valid())
+                       return die_("!block.is_valid()");
+               if(blockcopy != cuesheet_)
+                       return die_("copy is not identical to original");
+               printf("OK\n");
+       }
+
+       printf("testing CueSheet::CueSheet(const ::FLAC__StreamMetadata *, copy=false)... +\n");
+       printf("        CueSheet::operator!=(const ::FLAC__StreamMetadata *)... ");
+       {
+               ::FLAC__StreamMetadata *copy = ::FLAC__metadata_object_clone(&cuesheet_);
+               FLAC::Metadata::CueSheet blockcopy(copy, /*copy=*/false);
+               if(!blockcopy.is_valid())
+                       return die_("!block.is_valid()");
+               if(blockcopy != cuesheet_)
+                       return die_("copy is not identical to original");
+               printf("OK\n");
+       }
+
+       printf("testing CueSheet::assign(const ::FLAC__StreamMetadata *, copy=true)... +\n");
+       printf("        CueSheet::operator!=(const ::FLAC__StreamMetadata *)... ");
+       {
+               FLAC::Metadata::CueSheet blockcopy;
+               blockcopy.assign(&cuesheet_, /*copy=*/true);
+               if(!blockcopy.is_valid())
+                       return die_("!block.is_valid()");
+               if(blockcopy != cuesheet_)
+                       return die_("copy is not identical to original");
+               printf("OK\n");
+       }
+
+       printf("testing CueSheet::assign(const ::FLAC__StreamMetadata *, copy=false)... +\n");
+       printf("        CueSheet::operator!=(const ::FLAC__StreamMetadata *)... ");
+       {
+               ::FLAC__StreamMetadata *copy = ::FLAC__metadata_object_clone(&cuesheet_);
+               FLAC::Metadata::CueSheet blockcopy;
+               blockcopy.assign(copy, /*copy=*/false);
+               if(!blockcopy.is_valid())
+                       return die_("!block.is_valid()");
+               if(blockcopy != cuesheet_)
+                       return die_("copy is not identical to original");
+               printf("OK\n");
+       }
+
        printf("testing CueSheet::operator=(const CueSheet &)... +\n");
        printf("        CueSheet::operator==(const CueSheet &)... ");
        {