Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(3)

Side by Side Diff: test/mjsunit/object-define-property.js

Issue 6286060: Fix bugs 992, 1083 and 1092 (Closed) Base URL: https://v8.googlecode.com/svn/branches/bleeding_edge
Patch Set: Address review comments Created 9 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « src/v8natives.js ('k') | test/mjsunit/regress/regress-1083.js » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2010 the V8 project authors. All rights reserved. 1 // Copyright 2010 the V8 project authors. All rights reserved.
2 // Redistribution and use in source and binary forms, with or without 2 // Redistribution and use in source and binary forms, with or without
3 // modification, are permitted provided that the following conditions are 3 // modification, are permitted provided that the following conditions are
4 // met: 4 // met:
5 // 5 //
6 // * Redistributions of source code must retain the above copyright 6 // * Redistributions of source code must retain the above copyright
7 // notice, this list of conditions and the following disclaimer. 7 // notice, this list of conditions and the following disclaimer.
8 // * Redistributions in binary form must reproduce the above 8 // * Redistributions in binary form must reproduce the above
9 // copyright notice, this list of conditions and the following 9 // copyright notice, this list of conditions and the following
10 // disclaimer in the documentation and/or other materials provided 10 // disclaimer in the documentation and/or other materials provided
(...skipping 731 matching lines...) Expand 10 before | Expand all | Expand 10 after
742 assertTrue(desc.configurable); 742 assertTrue(desc.configurable);
743 743
744 // Redefine existing property with configurable: false. 744 // Redefine existing property with configurable: false.
745 Object.defineProperty(obj6, '2', descElementNonConfigurable); 745 Object.defineProperty(obj6, '2', descElementNonConfigurable);
746 desc = Object.getOwnPropertyDescriptor(obj6, '2'); 746 desc = Object.getOwnPropertyDescriptor(obj6, '2');
747 assertEquals(desc.value, 'barfoo'); 747 assertEquals(desc.value, 'barfoo');
748 assertTrue(desc.writable); 748 assertTrue(desc.writable);
749 assertTrue(desc.enumerable); 749 assertTrue(desc.enumerable);
750 assertFalse(desc.configurable); 750 assertFalse(desc.configurable);
751 751
752 // Ensure that we can't overwrite the non configurable element. 752 // Can use defineProperty to change the value of a non
753 // configurable property.
753 try { 754 try {
754 Object.defineProperty(obj6, '2', descElement); 755 Object.defineProperty(obj6, '2', descElement);
756 desc = Object.getOwnPropertyDescriptor(obj6, '2');
757 assertEquals(desc.value, 'foobar');
758 } catch (e) {
759 assertUnreachable();
760 }
761
762 // Ensure that we can't change the descriptor of a
763 // non configurable property.
764 try {
765 var descAccessor = { get: function() { return 0; } };
766 Object.defineProperty(obj6, '2', descAccessor);
755 assertUnreachable(); 767 assertUnreachable();
756 } catch (e) { 768 } catch (e) {
757 assertTrue(/Cannot redefine property/.test(e)); 769 assertTrue(/Cannot redefine property/.test(e));
758 } 770 }
759 771
772 Object.defineProperty(obj6, '2', descElementNonWritable);
773 desc = Object.getOwnPropertyDescriptor(obj6, '2');
774 assertEquals(desc.value, 'foofoo');
775 assertFalse(desc.writable);
776 assertTrue(desc.enumerable);
777 assertFalse(desc.configurable);
778
760 Object.defineProperty(obj6, '3', descElementNonWritable); 779 Object.defineProperty(obj6, '3', descElementNonWritable);
761 desc = Object.getOwnPropertyDescriptor(obj6, '3'); 780 desc = Object.getOwnPropertyDescriptor(obj6, '3');
762 assertEquals(desc.value, 'foofoo'); 781 assertEquals(desc.value, 'foofoo');
763 assertFalse(desc.writable); 782 assertFalse(desc.writable);
764 assertTrue(desc.enumerable); 783 assertTrue(desc.enumerable);
765 assertTrue(desc.configurable); 784 assertTrue(desc.configurable);
766 785
767 // Redefine existing property with configurable: false. 786 // Redefine existing property with configurable: false.
768 Object.defineProperty(obj6, '4', descElementNonEnumerable); 787 Object.defineProperty(obj6, '4', descElementNonEnumerable);
769 desc = Object.getOwnPropertyDescriptor(obj6, '4'); 788 desc = Object.getOwnPropertyDescriptor(obj6, '4');
(...skipping 50 matching lines...) Expand 10 before | Expand all | Expand 10 after
820 assertTrue(desc.configurable); 839 assertTrue(desc.configurable);
821 840
822 // Redefine existing property with configurable: false. 841 // Redefine existing property with configurable: false.
823 Object.defineProperty(arr, '2', descElementNonConfigurable); 842 Object.defineProperty(arr, '2', descElementNonConfigurable);
824 desc = Object.getOwnPropertyDescriptor(arr, '2'); 843 desc = Object.getOwnPropertyDescriptor(arr, '2');
825 assertEquals(desc.value, 'barfoo'); 844 assertEquals(desc.value, 'barfoo');
826 assertTrue(desc.writable); 845 assertTrue(desc.writable);
827 assertTrue(desc.enumerable); 846 assertTrue(desc.enumerable);
828 assertFalse(desc.configurable); 847 assertFalse(desc.configurable);
829 848
830 // Ensure that we can't overwrite the non configurable element. 849 // Can use defineProperty to change the value of a non
850 // configurable property of an array.
831 try { 851 try {
832 Object.defineProperty(arr, '2', descElement); 852 Object.defineProperty(arr, '2', descElement);
853 desc = Object.getOwnPropertyDescriptor(arr, '2');
854 assertEquals(desc.value, 'foobar');
855 } catch (e) {
856 assertUnreachable();
857 }
858
859 // Ensure that we can't change the descriptor of a
860 // non configurable property.
861 try {
862 var descAccessor = { get: function() { return 0; } };
863 Object.defineProperty(arr, '2', descAccessor);
833 assertUnreachable(); 864 assertUnreachable();
834 } catch (e) { 865 } catch (e) {
835 assertTrue(/Cannot redefine property/.test(e)); 866 assertTrue(/Cannot redefine property/.test(e));
836 } 867 }
837 868
869 Object.defineProperty(arr, '2', descElementNonWritable);
870 desc = Object.getOwnPropertyDescriptor(arr, '2');
871 assertEquals(desc.value, 'foofoo');
872 assertFalse(desc.writable);
873 assertTrue(desc.enumerable);
874 assertFalse(desc.configurable);
875
838 Object.defineProperty(arr, '3', descElementNonWritable); 876 Object.defineProperty(arr, '3', descElementNonWritable);
839 desc = Object.getOwnPropertyDescriptor(arr, '3'); 877 desc = Object.getOwnPropertyDescriptor(arr, '3');
840 assertEquals(desc.value, 'foofoo'); 878 assertEquals(desc.value, 'foofoo');
841 assertFalse(desc.writable); 879 assertFalse(desc.writable);
842 assertTrue(desc.enumerable); 880 assertTrue(desc.enumerable);
843 assertTrue(desc.configurable); 881 assertTrue(desc.configurable);
844 882
845 // Redefine existing property with configurable: false. 883 // Redefine existing property with configurable: false.
846 Object.defineProperty(arr, '4', descElementNonEnumerable); 884 Object.defineProperty(arr, '4', descElementNonEnumerable);
847 desc = Object.getOwnPropertyDescriptor(arr, '4'); 885 desc = Object.getOwnPropertyDescriptor(arr, '4');
(...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after
891 assertEquals(undefined, o.x); 929 assertEquals(undefined, o.x);
892 o.x = 37; 930 o.x = 37;
893 assertEquals(undefined, o.x); 931 assertEquals(undefined, o.x);
894 932
895 // Ignore inherited properties. 933 // Ignore inherited properties.
896 o = { __proto__ : { x : 87 } }; 934 o = { __proto__ : { x : 87 } };
897 Object.defineProperty(o, "x", { writable: false }); 935 Object.defineProperty(o, "x", { writable: false });
898 assertEquals(undefined, o.x); 936 assertEquals(undefined, o.x);
899 o.x = 37; 937 o.x = 37;
900 assertEquals(undefined, o.x); 938 assertEquals(undefined, o.x);
939
940 function testDefineProperty(obj, propertyName, desc, resultDesc) {
941 Object.defineProperty(obj, propertyName, desc);
942 var actualDesc = Object.getOwnPropertyDescriptor(obj, propertyName);
943 assertEquals(resultDesc.enumerable, actualDesc.enumerable);
944 assertEquals(resultDesc.configurable, actualDesc.configurable);
945 if (resultDesc.hasOwnProperty('value')) {
946 assertEquals(resultDesc.value, actualDesc.value);
947 assertEquals(resultDesc.writable, actualDesc.writable);
948 assertFalse(resultDesc.hasOwnProperty('get'));
949 assertFalse(resultDesc.hasOwnProperty('set'));
950 } else {
951 assertEquals(resultDesc.get, actualDesc.get);
952 assertEquals(resultDesc.set, actualDesc.set);
953 assertFalse(resultDesc.hasOwnProperty('value'));
954 assertFalse(resultDesc.hasOwnProperty('writable'));
955 }
956 }
957
958 // tests redefining existing property with a generic descriptor
959 o = { p : 42 };
960 testDefineProperty(o, 'p',
961 { },
962 { value : 42, writable : true, enumerable : true, configurable : true });
963
964 o = { p : 42 };
965 testDefineProperty(o, 'p',
966 { enumerable : true },
967 { value : 42, writable : true, enumerable : true, configurable : true });
968
969 o = { p : 42 };
970 testDefineProperty(o, 'p',
971 { configurable : true },
972 { value : 42, writable : true, enumerable : true, configurable : true });
973
974 o = { p : 42 };
975 testDefineProperty(o, 'p',
976 { enumerable : false },
977 { value : 42, writable : true, enumerable : false, configurable : true });
978
979 o = { p : 42 };
980 testDefineProperty(o, 'p',
981 { configurable : false },
982 { value : 42, writable : true, enumerable : true, configurable : false });
983
984 o = { p : 42 };
985 testDefineProperty(o, 'p',
986 { enumerable : true, configurable : true },
987 { value : 42, writable : true, enumerable : true, configurable : true });
988
989 o = { p : 42 };
990 testDefineProperty(o, 'p',
991 { enumerable : false, configurable : true },
992 { value : 42, writable : true, enumerable : false, configurable : true });
993
994 o = { p : 42 };
995 testDefineProperty(o, 'p',
996 { enumerable : true, configurable : false },
997 { value : 42, writable : true, enumerable : true, configurable : false });
998
999 o = { p : 42 };
1000 testDefineProperty(o, 'p',
1001 { enumerable : false, configurable : false },
1002 { value : 42, writable : true, enumerable : false, configurable : false });
1003
1004 // can make a writable, non-configurable field non-writable
1005 o = { p : 42 };
1006 Object.defineProperty(o, 'p', { configurable: false });
1007 testDefineProperty(o, 'p',
1008 { writable: false },
1009 { value : 42, writable : false, enumerable : true, configurable : false });
1010
1011 // redefine of get only property with generic descriptor
1012 o = {};
1013 Object.defineProperty(o, 'p',
1014 { get : getter1, enumerable: true, configurable: true });
1015 testDefineProperty(o, 'p',
1016 { enumerable : false, configurable : false },
1017 { get: getter1, set: undefined, enumerable : false, configurable : false });
1018
1019 // redefine of get/set only property with generic descriptor
1020 o = {};
1021 Object.defineProperty(o, 'p',
1022 { get: getter1, set: setter1, enumerable: true, configurable: true });
1023 testDefineProperty(o, 'p',
1024 { enumerable : false, configurable : false },
1025 { get: getter1, set: setter1, enumerable : false, configurable : false });
1026
1027 // redefine of set only property with generic descriptor
1028 o = {};
1029 Object.defineProperty(o, 'p',
1030 { set : setter1, enumerable: true, configurable: true });
1031 testDefineProperty(o, 'p',
1032 { enumerable : false, configurable : false },
1033 { get: undefined, set: setter1, enumerable : false, configurable : false });
OLDNEW
« no previous file with comments | « src/v8natives.js ('k') | test/mjsunit/regress/regress-1083.js » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698