enclosure_test.go 1.2 KB

123456789101112131415161718192021222324252627282930313233
  1. // SPDX-FileCopyrightText: Copyright The Miniflux Authors. All rights reserved.
  2. // SPDX-License-Identifier: Apache-2.0
  3. package model
  4. import (
  5. "testing"
  6. )
  7. func TestEnclosure_Html5MimeTypeGivesOriginalMimeType(t *testing.T) {
  8. enclosure := Enclosure{MimeType: "thing/thisMimeTypeIsNotExpectedToBeReplaced"}
  9. if enclosure.Html5MimeType() != enclosure.MimeType {
  10. t.Fatalf(
  11. "HTML5 MimeType must provide original MimeType if not explicitly Replaced. Got %s ,expected '%s' ",
  12. enclosure.Html5MimeType(),
  13. enclosure.MimeType,
  14. )
  15. }
  16. }
  17. func TestEnclosure_Html5MimeTypeReplaceStandardM4vByAppleSpecificMimeType(t *testing.T) {
  18. enclosure := Enclosure{MimeType: "video/m4v"}
  19. if enclosure.Html5MimeType() != "video/x-m4v" {
  20. // Solution from this stackoverflow discussion:
  21. // https://stackoverflow.com/questions/15277147/m4v-mimetype-video-mp4-or-video-m4v/66945470#66945470
  22. // tested at the time of this commit (06/2023) on latest Firefox & Vivaldi on this feed
  23. // https://www.florenceporcel.com/podcast/lfhdu.xml
  24. t.Fatalf(
  25. "HTML5 MimeType must be replaced by 'video/x-m4v' when originally video/m4v to ensure playbacks in brownser. Got '%s'",
  26. enclosure.Html5MimeType(),
  27. )
  28. }
  29. }