You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							112 lines
						
					
					
						
							3.5 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							112 lines
						
					
					
						
							3.5 KiB
						
					
					
				
								var assert = require("assert");
							 | 
						|
								
							 | 
						|
								var hamjest = require("hamjest");
							 | 
						|
								var assertThat = hamjest.assertThat;
							 | 
						|
								var contains = hamjest.contains;
							 | 
						|
								var equalTo = hamjest.equalTo;
							 | 
						|
								var hasProperties = hamjest.hasProperties;
							 | 
						|
								
							 | 
						|
								var mammoth = require("../");
							 | 
						|
								var documents = require("../lib/documents");
							 | 
						|
								var promises = require("../lib/promises");
							 | 
						|
								
							 | 
						|
								var test = require("./test")(module);
							 | 
						|
								
							 | 
						|
								
							 | 
						|
								test('mammoth.images.inline() should be an alias of mammoth.images.imgElement()', function() {
							 | 
						|
								    assert.ok(mammoth.images.inline === mammoth.images.imgElement);
							 | 
						|
								});
							 | 
						|
								
							 | 
						|
								
							 | 
						|
								test('mammoth.images.dataUri() encodes images in base64', function() {
							 | 
						|
								    var imageBuffer = new Buffer("abc");
							 | 
						|
								    var image = new documents.Image({
							 | 
						|
								        readImage: function(encoding) {
							 | 
						|
								            return promises.when(imageBuffer.toString(encoding));
							 | 
						|
								        },
							 | 
						|
								        contentType: "image/jpeg"
							 | 
						|
								    });
							 | 
						|
								
							 | 
						|
								    return mammoth.images.dataUri(image).then(function(result) {
							 | 
						|
								        assertThat(result, contains(
							 | 
						|
								            hasProperties({tag: hasProperties({attributes: {"src": ""}})})
							 | 
						|
								        ));
							 | 
						|
								    });
							 | 
						|
								});
							 | 
						|
								
							 | 
						|
								
							 | 
						|
								test('mammoth.images.imgElement()', {
							 | 
						|
								    'when element does not have alt text then alt attribute is not set': function() {
							 | 
						|
								        var imageBuffer = new Buffer("abc");
							 | 
						|
								        var image = new documents.Image({
							 | 
						|
								            readImage: function(encoding) {
							 | 
						|
								                return promises.when(imageBuffer.toString(encoding));
							 | 
						|
								            },
							 | 
						|
								            contentType: "image/jpeg"
							 | 
						|
								        });
							 | 
						|
								
							 | 
						|
								        var result = mammoth.images.imgElement(function(image) {
							 | 
						|
								            return {src: "<src>"};
							 | 
						|
								        })(image);
							 | 
						|
								
							 | 
						|
								        return result.then(function(result) {
							 | 
						|
								            assertThat(result, contains(
							 | 
						|
								                hasProperties({
							 | 
						|
								                    tag: hasProperties({
							 | 
						|
								                        attributes: equalTo({src: "<src>"})
							 | 
						|
								                    })
							 | 
						|
								                })
							 | 
						|
								            ));
							 | 
						|
								        });
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    'when element has alt text then alt attribute is set': function() {
							 | 
						|
								        var imageBuffer = new Buffer("abc");
							 | 
						|
								        var image = new documents.Image({
							 | 
						|
								            readImage: function(encoding) {
							 | 
						|
								                return promises.when(imageBuffer.toString(encoding));
							 | 
						|
								            },
							 | 
						|
								            contentType: "image/jpeg",
							 | 
						|
								            altText: "<alt>"
							 | 
						|
								        });
							 | 
						|
								
							 | 
						|
								        var result = mammoth.images.imgElement(function(image) {
							 | 
						|
								            return {src: "<src>"};
							 | 
						|
								        })(image);
							 | 
						|
								
							 | 
						|
								        return result.then(function(result) {
							 | 
						|
								            assertThat(result, contains(
							 | 
						|
								                hasProperties({
							 | 
						|
								                    tag: hasProperties({
							 | 
						|
								                        attributes: equalTo({alt: "<alt>", src: "<src>"})
							 | 
						|
								                    })
							 | 
						|
								                })
							 | 
						|
								            ));
							 | 
						|
								        });
							 | 
						|
								    },
							 | 
						|
								
							 | 
						|
								    'image alt text can be overridden by alt attribute returned from function': function() {
							 | 
						|
								        var imageBuffer = new Buffer("abc");
							 | 
						|
								        var image = new documents.Image({
							 | 
						|
								            readImage: function(encoding) {
							 | 
						|
								                return promises.when(imageBuffer.toString(encoding));
							 | 
						|
								            },
							 | 
						|
								            contentType: "image/jpeg",
							 | 
						|
								            altText: "<alt>"
							 | 
						|
								        });
							 | 
						|
								
							 | 
						|
								        var result = mammoth.images.imgElement(function(image) {
							 | 
						|
								            return {alt: "<alt override>", src: "<src>"};
							 | 
						|
								        })(image);
							 | 
						|
								
							 | 
						|
								        return result.then(function(result) {
							 | 
						|
								            assertThat(result, contains(
							 | 
						|
								                hasProperties({
							 | 
						|
								                    tag: hasProperties({
							 | 
						|
								                        attributes: equalTo({alt: "<alt override>", src: "<src>"})
							 | 
						|
								                    })
							 | 
						|
								                })
							 | 
						|
								            ));
							 | 
						|
								        });
							 | 
						|
								    }
							 | 
						|
								});
							 | 
						|
								
							 |