cách khắc phục cảnh báo 404 cho hình ảnh trong quá trình kiểm tra đơn vị nghiệp


84

Tôi đang thử nghiệm đơn vị một trong những chỉ thị của mình (anglejs) bằng cách sử dụng grunt / karma / phantomjs / jasmine. Các bài kiểm tra của tôi chạy tốt

describe('bar foo', function () {
    beforeEach(inject(function ($rootScope, $compile) {
        elm = angular.element('<img bar-foo src="img1.png"/>');
        scope = $rootScope.$new();
        $compile(elm)();
        scope.$digest();
    }));
    ....
});

nhưng tôi nhận được những 404

WARN [web-server]: 404: /img1.png
WARN [web-server]: 404: /img2.png
...

Mặc dù chúng không làm gì cả, chúng sẽ thêm nhiễu vào đầu ra nhật ký. Có cách nào để sửa lỗi này ? (Tất nhiên là không thay đổi logLevel của karma, vì tôi muốn thấy chúng)


Nó có tồn tại trong một trình duyệt khác không? Tôi biết có một số vấn đề đã biết với lỗi 404 đối với các loại cuộc gọi này trong FF.
Nicholas Hazel

nó phải là phantomjs. Tôi đã kiểm tra Chrome cũng hiển thị 404. Lưu ý rằng chúng là cảnh báo, không phải lỗi!
Jeanluca Scaljeri

Sử dụng ng-src có giúp ích gì không?
Eitan Peer

thoải mái thử, nhưng có kết quả tương tự
Jeanluca Scaljeri

Câu trả lời:


109

Đó là bởi vì bạn cần phải định cấu hình nghiệp để tải sau đó phục vụ chúng khi được yêu cầu;)

Trong tệp karma.conf.js của bạn, bạn nên có các tệp và / hoặc mẫu được xác định như:

// list of files / patterns to load in the browser
files : [
  {pattern: 'app/lib/angular.js', watched: true, included: true, served: true},
  {pattern: 'app/lib/angular-*.js', watched: true, included: true, served: true},
  {pattern: 'app/lib/**/*.js', watched: true, included: true, served: true},
  {pattern: 'app/js/**/*.js', watched: true, included: true, served: true},
  // add the line below with the correct path pattern for your case
  {pattern: 'path/to/**/*.png', watched: false, included: false, served: true},
  // important: notice that "included" must be false to avoid errors
  // otherwise Karma will include them as scripts
  {pattern: 'test/lib/**/*.js', watched: true, included: true, served: true},
  {pattern: 'test/unit/**/*.js', watched: true, included: true, served: true},
],

// list of files to exclude
exclude: [

],

// ...

Bạn có thể xem ở đây để biết thêm thông tin :)

CHỈNH SỬA: Nếu bạn sử dụng máy chủ web nodejs để chạy ứng dụng của mình, bạn có thể thêm nó vào karma.conf.js:

proxies: {
  '/path/to/img/': 'http://localhost:8000/path/to/img/'
},

EDIT2: Nếu bạn không sử dụng hoặc muốn sử dụng máy chủ khác, bạn có thể xác định proxy cục bộ nhưng vì Karma không cung cấp quyền truy cập vào cổng đang sử dụng, theo cách động, nếu karma bắt đầu trên một cổng khác 9876 (mặc định), bạn vẫn sẽ nhận được những 404 khó chịu ...

proxies =  {
  '/images/': '/base/images/'
};

Vấn đề liên quan: https://github.com/karma-runner/karma/issues/872


4
Trong trường hợp của tôi những hình ảnh này không tồn tại. Giải pháp bạn cung cấp giả định các tệp tồn tại, phải không?
Jeanluca Scaljeri

Phải, tất nhiên! Tôi nghĩ rằng tôi đã hiểu lầm, nó có lý do để có lỗi 404 cho các tệp không tồn tại, phải không? Bạn muốn ẩn các cảnh báo liên quan đến hình ảnh? Nếu không thay đổi cấp độ nhật ký, tôi không thấy giải pháp nào, hơn nữa, điều đó sẽ ẩn các cảnh báo khác, điều này sẽ gây rủi ro. Tại sao không tạo tệp .png trống trong thư mục "test / img" chẳng hạn? :)
glepretre

Vì một số lý do tôi không thể làm cho nó hoạt động. Mối quan hệ chính xác giữa url được sử dụng trong HTML và mẫu trong karma.conf.js là gì? Ví dụ: nếu tôi có một hình ảnh trong test / asset / img.png , url sẽ là gì?
Jeanluca Scaljeri

1
Tôi xin lỗi, giải pháp này sẽ hoạt động nhưng tôi vẫn gặp lỗi 404. Tôi tin rằng điều này có liên quan đến việc thiếu triển khai Karma và tôi ngạc nhiên rằng chúng tôi là người duy nhất có được nó. Tôi đã tìm thấy một cách (hơi hack) để làm cho điều này hoạt động nhưng bạn sẽ cần chạy một máy chủ (web) khác song song với Karma. Tôi sẽ chỉnh sửa câu trả lời của mình. ;)
glepretre

3
Đáp lại EDIT2 nếu bạn chạy karma trên một cổng tùy chỉnh, bạn có thể tránh 404 bằng cách liên kết với URI đầy đủ của máy chủ karma: (giả sử port: 9999)proxies = { '/images/': 'http://localhost:9999/base/images/' };
Josh

18

Mảnh ghép khó hiểu đối với tôi là thư mục ảo 'cơ sở'. Nếu bạn không biết điều đó cần được đưa vào đường dẫn nội dung của đồ đạc của mình, bạn sẽ khó gỡ lỗi.

Theo tài liệu cấu hình

Theo mặc định, tất cả nội dung được phân phát tại http: // localhost: [PORT] / base /

Lưu ý: điều này có thể không đúng với các phiên bản khác - tôi đang sử dụng 0.12.14 và nó hoạt động với tôi nhưng tài liệu 0.10 không đề cập đến nó.

Sau khi chỉ định mẫu tệp:

{ pattern: 'Test/images/*.gif', watched: false, included: false, served: true, nocache: false },

Tôi có thể sử dụng cái này trong đồ đạc của mình:

<img src="base/Test/images/myimage.gif" />

Và tôi không cần proxy vào thời điểm đó.


Đây là móc sắt. Câu trả lời hàng đầu giải thích điều này nhưng rất ngắn gọn - cảm ơn bạn đã mở rộng.
jlb

10

Bạn có thể tạo phần mềm trung gian chung bên trong karma.conf.js của mình - hơi cao nhưng đã làm được việc cho tôi

Đầu tiên xác định hình ảnh giả 1px (tôi đã sử dụng base64):

const DUMMIES = {
  png: {
    base64: '',
    type: 'image/png'
  },
  jpg: {
    base64: '',
    type: 'image/jpeg'
  },
  gif: {
    base64: '',
    type: 'image/gif'
  }
};

Sau đó xác định chức năng phần mềm trung gian:

function surpassImage404sMiddleware(req, res, next) {
  const imageExt = req.url.split('.').pop();
  const dummy = DUMMIES[imageExt];

  if (dummy) {
    // Table of files to ignore
    const imgPaths = ['/another-cat-image.png'];
    const isFakeImage = imgPaths.indexOf(req.url) !== -1;

    // URL to ignore
    const isCMSImage = req.url.indexOf('/cms/images/') !== -1;

    if (isFakeImage || isCMSImage) {
      const img = Buffer.from(dummy.base64, 'base64');
      res.writeHead(200, {
        'Content-Type': dummy.type,
        'Content-Length': img.length
      });
      return res.end(img);
    }
  }
  next();
}

Áp dụng phần mềm trung gian trong nghiệp vụ của bạn

{
    basePath: '',
    frameworks: ['jasmine', '@angular/cli'],
    middleware: ['surpassImage404sMiddleware'],
    plugins: [
      ...
      {'middleware:surpassImage404sMiddleware': ['value', surpassImage404sMiddleware]}
    ],
    ...
}

Bạn đã bao giờ làm cho nó thành một gói thực tế? Tôi rất thích chỉ npm cài đặt cái này
Akxe

Nếu bạn muốn chặn tất cả các yêu cầu hình ảnh, chỉ cần kiểm tra req.headers.acceptxem nó có chứa imagehay không và trả về 204 nếu có.
cleong

9

Dựa trên câu trả lời của @ glepretre, tôi đã tạo một tệp .png trống và thêm tệp này vào cấu hình để ẩn cảnh báo 404:

proxies: {
  '/img/generic.png': 'test/assets/img/generic.png'
}

3

Để khắc phục, karma.conf.jshãy nhớ trỏ đến tệp được cung cấp bằng proxy của bạn:

files: [
  { pattern: './src/img/fake.jpg', watched: false, included: false, served: true },
],
proxies: {
  '/image.jpg': '/base/src/img/fake.jpg',
  '/fake-avatar': '/base/src/img/fake.jpg',
  '/folder/0x500.jpg': '/base/src/img/fake.jpg',
  '/undefined': '/base/src/img/fake.jpg'
}

3

Mặc dù nó là một chủ đề cũ, tôi đã mất vài giờ để thực sự có được hình ảnh của mình để thực sự được phục vụ từ nghiệp chướng để loại bỏ 404. Các ý kiến ​​chỉ là không đủ kỹ lưỡng. Tôi tin rằng tôi có thể làm rõ giải pháp với ảnh chụp màn hình này. Về cơ bản, một điều mà nhiều nhận xét còn thiếu là thực tế là giá trị proxy phải bắt đầu bằng "/ base" , mặc dù base không có trong bất kỳ thư mục nào của tôi, cũng không có trong yêu cầu của tôi.

("base" không có dấu gạch chéo phía trước dẫn đến nghiệp trả về YÊU CẦU 400 BAD)

Bây giờ sau khi chạy thử nghiệm ng , tôi có thể phân phối thành công "./src/assets/favicon.png" từ url: http: // localhost: 9876 / test / dummy.png

Trong dự án của tôi, tôi đang sử dụng các phiên bản gói npm sau:

  • nghiệp v4.3.0
  • jasmine-core v3.2.1
  • karma-jasmine v1.1.2
  • @ angle / cli v8.3.5
  • góc v8.2.7

Cấu trúc dự án VSCode với vị trí tài sản karma.conf.js


Thông tin chi tiết này đặc biệt hữu ích để tôi hiểu rằng có sự khác biệt (theo quan điểm của Karma) đối với việc phân phát tệp trong khu vực cơ sở và từ bên ngoài khu vực cơ sở (cuối cùng là vấn đề của tôi), sau đó dẫn tôi đến github.com/karma -runner / nghiệp / vấn đề / 2703 . Vì vậy, cảm ơn bạn đã làm rõ điều này.
dpmott

2

Nếu bạn có đường dẫn gốc ở đâu đó trong tệp cấu hình của mình, bạn cũng có thể sử dụng một cái gì đó như sau:

proxies: {
  '/bower_components/': config.root + '/client/bower_components/'
}
Khi sử dụng trang web của chúng tôi, bạn xác nhận rằng bạn đã đọc và hiểu Chính sách cookieChính sách bảo mật của chúng tôi.
Licensed under cc by-sa 3.0 with attribution required.