ಹೆಡ್ಲೆಸ್ ಕ್ರೋಮ್ನೊಂದಿಗೆ ರಸ್ಟ್ನಲ್ಲಿ ಜಾವಾಸ್ಕ್ರಿಪ್ಟ್ ದೋಷಗಳನ್ನು ನಿರ್ವಹಿಸುವುದು
ಆನ್ಲೈನ್ ಆಟೊಮೇಷನ್ ಅಥವಾ ಪರೀಕ್ಷೆಯೊಂದಿಗೆ ವ್ಯವಹರಿಸುವಾಗ ಡೀಬಗ್ ಮಾಡಲು ಮತ್ತು ಕೋಡ್ ಸ್ಥಿರತೆಯನ್ನು ಖಾತರಿಪಡಿಸಲು JavaScript ಸಮಸ್ಯೆಗಳನ್ನು ಗುರುತಿಸುವುದು ಅತ್ಯಗತ್ಯವಾಗಿರುತ್ತದೆ. ರಸ್ಟ್ನಲ್ಲಿ ಹೆಡ್ಲೆಸ್ ಕ್ರೋಮ್ ಬ್ರೌಸರ್ ನಿದರ್ಶನದಲ್ಲಿ JavaScript ಅನ್ನು ರನ್ ಮಾಡಬಹುದು ಮತ್ತು ಮಾರ್ಪಡಿಸಬಹುದು ಧನ್ಯವಾದಗಳು ತಲೆಯಿಲ್ಲದ_ಕ್ರೋಮ್ ಕ್ರೇಟ್. ಆದಾಗ್ಯೂ, ದಸ್ತಾವೇಜನ್ನು ಕೊರತೆಯು JavaScript ಸಮಸ್ಯೆಗಳನ್ನು ಪತ್ತೆಹಚ್ಚಲು ಈ ಕ್ರೇಟ್ ಅನ್ನು ಬಳಸಲು ಕಷ್ಟಕರವಾಗಿಸುತ್ತದೆ.
ಈ ಲೇಖನವನ್ನು ಬಳಸಿಕೊಂಡು ಜಾವಾಸ್ಕ್ರಿಪ್ಟ್ ಸಮಸ್ಯೆಗಳನ್ನು ಹೇಗೆ ಗುರುತಿಸುವುದು ಎಂಬುದನ್ನು ವಿವರಿಸುತ್ತದೆ ತಲೆಯಿಲ್ಲದ_ಕ್ರೋಮ್ ಕ್ರೇಟ್ ಇನ್ ರಸ್ಟ್, ಸ್ಕ್ರಿಪ್ಟ್ ವಿಫಲಗೊಳ್ಳುವ ಸನ್ನಿವೇಶಗಳನ್ನು ನಿರ್ವಹಿಸುವುದರ ಮೇಲೆ ಒತ್ತು ನೀಡುತ್ತದೆ. ವಿಫಲವಾದ ಸಮರ್ಥನೆಗಳಂತಹ ಸಮಸ್ಯೆಗಳಿಗೆ ಕಣ್ಣಿಡಲು Chrome ನಲ್ಲಿ ಲಾಗಿಂಗ್ ಮತ್ತು ಡೀಬಗರ್ ಈವೆಂಟ್ಗಳನ್ನು ಹೇಗೆ ಬಳಸುವುದು ಎಂಬುದನ್ನು ನಾವು ನಿರ್ದಿಷ್ಟವಾಗಿ ನೋಡುತ್ತೇವೆ.
ನಿರ್ದಿಷ್ಟ ರೀತಿಯ JavaScript ವೈಫಲ್ಯಗಳನ್ನು ಮೇಲ್ವಿಚಾರಣೆ ಮಾಡಲು ರಸ್ಟ್ನಲ್ಲಿ ಈವೆಂಟ್ ಕೇಳುಗರನ್ನು ಸರಿಯಾಗಿ ಹೊಂದಿಸುವುದು ಡೆವಲಪರ್ಗಳು ಎದುರಿಸುತ್ತಿರುವ ತೊಂದರೆಗಳಲ್ಲಿ ಒಂದಾಗಿದೆ. ನಾವು ನೋಡುವಂತೆ, ಕಾರ್ಯಗಳನ್ನು ಬಳಸುವ ಮೊದಲು ಕೆಲವು ಸೆಟಪ್ ಅಗತ್ಯವಾಗಬಹುದು console.assert(false) ಪತ್ತೆಹಚ್ಚಬಹುದಾದ ಘಟನೆಗಳನ್ನು ತಕ್ಷಣವೇ ಸೃಷ್ಟಿಸಲು; ಇದು ರಸ್ಟ್ನ ಈವೆಂಟ್ ಹ್ಯಾಂಡ್ಲಿಂಗ್ ಸಾಮರ್ಥ್ಯಗಳ ಆಳವಾದ ಗ್ರಹಿಕೆಗೆ ಕರೆ ನೀಡುತ್ತದೆ.
ನಾವು ಕೋಡ್ ಮಾದರಿಗಳ ಮೂಲಕ ಹೋಗುತ್ತೇವೆ, ಸಾಮಾನ್ಯ ಸಮಸ್ಯೆಗಳನ್ನು ಪರಿಹರಿಸುತ್ತೇವೆ ಮತ್ತು ಮುಂಬರುವ ಭಾಗಗಳಲ್ಲಿ JavaScript ದೋಷಗಳನ್ನು ಪರಿಣಾಮಕಾರಿಯಾಗಿ ಹಿಡಿಯಲು ನಮ್ಮ ಈವೆಂಟ್ ಕೇಳುಗರನ್ನು ಸುಧಾರಿಸುತ್ತೇವೆ. ಸಂಪೂರ್ಣ ದಾಖಲಾತಿಯನ್ನು ಹೊಂದಿರದ ಕ್ರೇಟ್ಗಳೊಂದಿಗೆ ಕೆಲಸ ಮಾಡಲು ಹೇಗೆ ಪ್ರಯೋಗ ಮತ್ತು ದೋಷದ ಅಗತ್ಯವಿದೆ ಎಂಬುದನ್ನು ಈ ವಿಧಾನವು ತೋರಿಸುತ್ತದೆ.
ಆಜ್ಞೆ | ಬಳಕೆಯ ಉದಾಹರಣೆ |
---|---|
ಬ್ರೌಸರ್::ಹೊಸ() | ಅನ್ನು ಬಳಸುವುದು ತಲೆಯಿಲ್ಲದ_ಕ್ರೋಮ್ crate, ಈ ಆಜ್ಞೆಯು ಹೊಸ ಹೆಡ್ಲೆಸ್ ಕ್ರೋಮ್ ಬ್ರೌಸರ್ ನಿದರ್ಶನವನ್ನು ಪ್ರಾರಂಭಿಸುತ್ತದೆ. ವಿಂಡೋ ಗಾತ್ರ ಮತ್ತು ಬ್ರೌಸರ್ ಮಾರ್ಗ ಸೇರಿದಂತೆ ಕಸ್ಟಮ್ ಆರಂಭಿಕ ನಿಯತಾಂಕಗಳನ್ನು ಅದರೊಂದಿಗೆ ಕಾನ್ಫಿಗರ್ ಮಾಡಬಹುದು. |
LaunchOptions ::default_builder() | ಈ ಆಜ್ಞೆಯ ಸಹಾಯದಿಂದ, ಬ್ರೌಸರ್ ಸೆಟ್ಟಿಂಗ್ಗಳನ್ನು ಪ್ರಾರಂಭಿಸುವ ಮೊದಲು ಕಸ್ಟಮೈಸ್ ಮಾಡಬಹುದು. ವಿಂಡೋ ಗಾತ್ರ ಮತ್ತು ಬಳಕೆದಾರರ ಆದ್ಯತೆಗಳು ಸೇರಿದಂತೆ Chrome ನಿದರ್ಶನದ ನಿಯತಾಂಕಗಳ ಸಂಗ್ರಹಣೆಯ ನಿರ್ಮಾಣದಲ್ಲಿ ಇದನ್ನು ಬಳಸಿಕೊಳ್ಳಲಾಗಿದೆ. |
tab.new_tab() | Chrome ಸೆಷನ್ ಇನ್ನೂ ತೆರೆದಿರುವಾಗ ಬ್ರೌಸರ್ನಲ್ಲಿ ಹೊಸ ಟ್ಯಾಬ್ ತೆರೆಯುತ್ತದೆ. ನೀವು ಏಕಕಾಲದಲ್ಲಿ ಬಹು ಪುಟಗಳಿಗೆ ನ್ಯಾವಿಗೇಟ್ ಮಾಡಲು ಅಥವಾ ಬಹು ಜಾವಾಸ್ಕ್ರಿಪ್ಟ್ ಸ್ಕ್ರಿಪ್ಟ್ಗಳನ್ನು ಏಕಕಾಲದಲ್ಲಿ ಕಾರ್ಯಗತಗೊಳಿಸಲು ಬಯಸಿದರೆ ಇದು ಅಗತ್ಯವಾಗಿರುತ್ತದೆ. |
tab.enable_debugger() | ಸಕ್ರಿಯ ಟ್ಯಾಬ್ಗಾಗಿ Chrome ಡೀಬಗರ್ ಅನ್ನು ಆನ್ ಮಾಡುತ್ತದೆ, ಅದರೊಂದಿಗೆ ಪ್ರೋಗ್ರಾಮ್ಯಾಟಿಕ್ ಆಗಿ ಕೆಲಸ ಮಾಡಲು ಮತ್ತು JavaScript ವಿರಾಮಗಳು ಅಥವಾ ಸಮಸ್ಯೆಗಳಂತಹ ಡೀಬಗ್ ಈವೆಂಟ್ಗಳನ್ನು ಆಲಿಸಲು ನಿಮಗೆ ಅವಕಾಶ ನೀಡುತ್ತದೆ. |
tab.enable_log() | ಬ್ರೌಸರ್ ಟ್ಯಾಬ್ನಲ್ಲಿ ಲಾಗಿಂಗ್ ವೈಶಿಷ್ಟ್ಯವನ್ನು ಸಕ್ರಿಯಗೊಳಿಸುವ ಮೂಲಕ ಸೆಶನ್ನಲ್ಲಿ ಉತ್ಪತ್ತಿಯಾಗುವ JavaScript ಕನ್ಸೋಲ್ ಔಟ್ಪುಟ್ಗಳು, ದೋಷಗಳು ಮತ್ತು ಇತರ ಲಾಗ್ ಸಂದೇಶಗಳನ್ನು ರೆಕಾರ್ಡ್ ಮಾಡಲು ಮತ್ತು ಪರೀಕ್ಷಿಸಲು ಡೆವಲಪರ್ಗಳನ್ನು ಸಕ್ರಿಯಗೊಳಿಸುತ್ತದೆ. |
tab.add_event_listener() | ಈವೆಂಟ್ ಆಲಿಸುವವರ ಸೇರ್ಪಡೆಯೊಂದಿಗೆ, ಬ್ರೌಸರ್ನ ಡೀಬಗರ್ ಈಗ ಕೆಲವು ಈವೆಂಟ್ಗಳಿಗೆ ಪ್ರತಿಕ್ರಿಯಿಸಬಹುದು, ಉದಾಹರಣೆಗೆ ಡೀಬಗರ್ ವಿರಾಮಗೊಳಿಸಲಾಗಿದೆ, ಮತ್ತು JavaScript ದೋಷಗಳು ಕಂಡುಬಂದಾಗ ಎಚ್ಚರಿಕೆಗಳನ್ನು ನೀಡಿ. |
ಈವೆಂಟ್::DebuggerPaused() | ಸಾಮಾನ್ಯವಾಗಿ ಬ್ರೇಕ್ಪಾಯಿಂಟ್ ಅಥವಾ ದೋಷದ ಪರಿಣಾಮವಾಗಿ JavaScript ಎಕ್ಸಿಕ್ಯೂಶನ್ ಅನ್ನು ನಿಲ್ಲಿಸಲಾಗಿದೆ ಎಂದು ಪತ್ತೆಹಚ್ಚಿದ ಮೇಲೆ Chrome ಡೀಬಗರ್ನಿಂದ ನಿರ್ದಿಷ್ಟ ಕ್ರಮವನ್ನು ತೆಗೆದುಕೊಳ್ಳಲಾಗುತ್ತದೆ. ರನ್ಟೈಮ್ ಸಮಯದಲ್ಲಿ ವೈಫಲ್ಯಗಳನ್ನು ಸೆರೆಹಿಡಿಯಲು, ಇದು ಅತ್ಯಗತ್ಯ. |
tab.evaluate() | ಪ್ರಸ್ತುತ ಟ್ಯಾಬ್ನ ಸಂದರ್ಭದಲ್ಲಿ ಜಾವಾಸ್ಕ್ರಿಪ್ಟ್ ಅಭಿವ್ಯಕ್ತಿಯನ್ನು ನಿರ್ವಹಿಸುತ್ತದೆ. ಈ ಸಂದರ್ಭದಲ್ಲಿ, ಚಾಲನೆಯಲ್ಲಿರುವ ದೋಷವನ್ನು ಪ್ರಚೋದಿಸಲಾಗುತ್ತದೆ console.assert(false), ಮತ್ತು ಈವೆಂಟ್ ಕೇಳುಗರು ಅದನ್ನು ರೆಕಾರ್ಡ್ ಮಾಡುತ್ತಾರೆ. |
ಪ್ಯಾನಿಕ್::set_hook() | ರಸ್ಟ್ ಅಪ್ಲಿಕೇಶನ್ ಸಂಭವಿಸಿದಾಗ ದೋಷ ಮಾಹಿತಿಯನ್ನು ರೆಕಾರ್ಡ್ ಮಾಡಲು ಮತ್ತು ಪ್ಯಾನಿಕ್ಗಳನ್ನು ಸೆರೆಹಿಡಿಯಲು ಕಸ್ಟಮ್ ಪ್ಯಾನಿಕ್ ಹುಕ್ ಅನ್ನು ಕಾನ್ಫಿಗರ್ ಮಾಡುತ್ತದೆ. ಜಾವಾಸ್ಕ್ರಿಪ್ಟ್ ಸಮಸ್ಯೆಗಳನ್ನು ಗುರುತಿಸಲು ಮತ್ತು ಕಸ್ಟಮ್ ದೋಷ ನಿರ್ವಹಣೆಯನ್ನು ಸೇರಿಸಲು ಇದು ಸಹಾಯಕವಾಗಬಹುದು. |
ಎಸ್ಟಿಡಿ::ಥ್ರೆಡ್::ಸ್ಲೀಪ್() | ಪೂರ್ವನಿರ್ಧರಿತ ಸಮಯದವರೆಗೆ ಪ್ರೋಗ್ರಾಂನ ಕಾರ್ಯಗತಗೊಳಿಸುವಿಕೆಯನ್ನು ವಿರಾಮಗೊಳಿಸುತ್ತದೆ, ಜಾವಾಸ್ಕ್ರಿಪ್ಟ್ ಅನ್ನು ಚಲಾಯಿಸಲು ಸಮಯವನ್ನು ನೀಡುತ್ತದೆ ಮತ್ತು ಪ್ರೋಗ್ರಾಂ ಮುಗಿಯುವ ಮೊದಲು ಯಾವುದೇ ಸಂಭವನೀಯ ದೋಷಗಳನ್ನು ಕಂಡುಹಿಡಿಯಬಹುದು. |
ರಸ್ಟ್ನ ಹೆಡ್ಲೆಸ್ ಕ್ರೋಮ್ ಕ್ರೇಟ್ನೊಂದಿಗೆ ಜಾವಾಸ್ಕ್ರಿಪ್ಟ್ ದೋಷಗಳನ್ನು ಕಂಡುಹಿಡಿಯುವುದು ಹೇಗೆ
ರಸ್ಟ್ ಕ್ರೇಟ್ ಅನ್ನು ಬಳಸಿಕೊಂಡು ಹೆಡ್ಲೆಸ್ ಕ್ರೋಮ್ ಬ್ರೌಸರ್ನಲ್ಲಿ ಜಾವಾಸ್ಕ್ರಿಪ್ಟ್ ಕೋಡ್ ಅನ್ನು ರನ್ ಮಾಡುವುದು ಸ್ಕ್ರಿಪ್ಟ್ಗಳ ಉದ್ದೇಶವಾಗಿದೆ ತಲೆಯಿಲ್ಲದ_ಕ್ರೋಮ್ ಮತ್ತು ಉದ್ಭವಿಸುವ ಯಾವುದೇ JavaScript ಸಮಸ್ಯೆಗಳನ್ನು ಗುರುತಿಸಿ. ಜಾವಾಸ್ಕ್ರಿಪ್ಟ್ ಉದ್ದೇಶಿಸಿದಂತೆ ಕಾರ್ಯನಿರ್ವಹಿಸುತ್ತದೆ ಎಂದು ಖಚಿತಪಡಿಸಿಕೊಳ್ಳಲು ವೆಬ್ ಸ್ಕ್ರ್ಯಾಪಿಂಗ್ ಅಥವಾ ಸ್ವಯಂಚಾಲಿತ ಪರೀಕ್ಷೆಯನ್ನು ಬಳಸುವಾಗ ಇದು ವಿಶೇಷವಾಗಿ ಸಹಾಯಕವಾಗಿದೆ. ಬಳಸುತ್ತಿದೆ ಬ್ರೌಸರ್::ಹೊಸ, ಸ್ಕ್ರಿಪ್ಟ್ ಮೊದಲು ಬ್ರೌಸರ್ನ ಹೊಸ ನಿದರ್ಶನವನ್ನು ಪ್ರಾರಂಭಿಸುತ್ತದೆ ಮತ್ತು ಕೆಲವನ್ನು ಹೊಂದಿಸುತ್ತದೆ ಲಾಂಚ್ ಆಯ್ಕೆಗಳು, ಉದಾಹರಣೆಗೆ ವಿಂಡೋ ಗಾತ್ರ. ಹೆಡ್ಲೆಸ್ ಕ್ರೋಮ್ ನಿದರ್ಶನವು ನಿಜವಾದ ಬ್ರೌಸರ್ ಪರಿಸರದಂತೆ ಕಾರ್ಯನಿರ್ವಹಿಸುತ್ತದೆ ಎಂದು ಖಚಿತಪಡಿಸಿಕೊಳ್ಳಲು, ಈ ಸೆಟ್ಟಿಂಗ್ಗಳನ್ನು ರವಾನಿಸಲಾಗಿದೆ.
ಸ್ಕ್ರಿಪ್ಟ್ ಬಳಸುತ್ತದೆ tab.new_tab() ಬ್ರೌಸರ್ ಅನ್ನು ಪ್ರಾರಂಭಿಸಿದ ನಂತರ ಹೊಸ ಟ್ಯಾಬ್ ಅನ್ನು ರಚಿಸಲು. ಈ ಟ್ಯಾಬ್ ಬ್ರೌಸರ್ ವಿಂಡೋವನ್ನು ಹೋಲುವ ರೀತಿಯಲ್ಲಿ JavaScript ಅನ್ನು ರನ್ ಮಾಡುತ್ತದೆ. ಬಳಸುವ ಮೂಲಕ ನಾವು JavaScript ದೋಷಗಳನ್ನು ಒಳಗೊಂಡಂತೆ ನಿರ್ಣಾಯಕ ಘಟನೆಗಳನ್ನು ಆಲಿಸಬಹುದು tab.enable_debugger() ಮತ್ತು tab.enable_log() Chrome ಡೀಬಗರ್ ಮತ್ತು ಲಾಗಿಂಗ್ ವೈಶಿಷ್ಟ್ಯಗಳನ್ನು ಸಕ್ರಿಯಗೊಳಿಸಲು. ನಿರ್ದಿಷ್ಟವಾಗಿ ಹೇಳುವುದಾದರೆ, ಈ ಸಾಮರ್ಥ್ಯಗಳನ್ನು ಆನ್ ಮಾಡುವುದರಿಂದ Chrome ನ ಅಂತರ್ನಿರ್ಮಿತ ಡೀಬಗ್ ಮಾಡುವ ಪ್ರೋಟೋಕಾಲ್ ಅನ್ನು ಬಳಸಲು ಸ್ಕ್ರಿಪ್ಟ್ ಅನ್ನು ಸಕ್ರಿಯಗೊಳಿಸುತ್ತದೆ, ಇದು ಸಾಂಪ್ರದಾಯಿಕ ಲಾಗಿಂಗ್ ವಿಧಾನಗಳ ಮೂಲಕ ಸ್ಪಷ್ಟವಾಗಿ ಕಂಡುಬರದ ದೋಷಗಳನ್ನು ಹಿಡಿಯಲು ಅವಶ್ಯಕವಾಗಿದೆ.
ಮುಂದೆ, ದಿ tab.add_event_listener() ಈವೆಂಟ್ ಕೇಳುಗರನ್ನು ಬಳಸಿಕೊಳ್ಳಲು ಸ್ಕ್ರಿಪ್ಟ್ನಿಂದ ವಿಧಾನವನ್ನು ಬಳಸಲಾಗುತ್ತದೆ. ಈ ಕಾರ್ಯವು ನಿರ್ದಿಷ್ಟ ಡೀಬಗ್ ಮಾಡುವ ಘಟನೆಗಳನ್ನು ರೆಕಾರ್ಡ್ ಮಾಡಲು ವ್ಯವಸ್ಥೆಯನ್ನು ರಚಿಸುತ್ತದೆ ಡೀಬಗರ್ ವಿರಾಮಗೊಳಿಸಲಾಗಿದೆ, ಇದು ಜಾವಾಸ್ಕ್ರಿಪ್ಟ್ ಸಮಸ್ಯೆ ಅಥವಾ ಬ್ರೇಕ್ಪಾಯಿಂಟ್ನಿಂದಾಗಿ ಕಾರ್ಯಗತಗೊಳಿಸುವಿಕೆಯು ಅಡಚಣೆಯಾಗಿದೆ ಎಂಬ ಸೂಚನೆಯಾಗಿದೆ. ಈವೆಂಟ್ ಕೇಳುಗರು ಇದನ್ನು ರಸ್ಟ್ ಮುಚ್ಚುವಿಕೆಯಲ್ಲಿ ಸೇರಿಸುವ ಮೂಲಕ JavaScript ದೋಷವಿದೆಯೇ ಎಂದು ನಿರ್ಧರಿಸುತ್ತಾರೆ. ದೋಷ ಕಂಡುಬಂದರೆ ಸಾಫ್ಟ್ವೇರ್ ಪ್ಯಾನಿಕ್ ಮಾಡುತ್ತದೆ ಮತ್ತು ದೋಷ ಸಂದೇಶವನ್ನು ಪ್ರದರ್ಶಿಸುತ್ತದೆ. ಈ ವಿಧಾನದಿಂದ, ತಲೆಯಿಲ್ಲದೆ ಕಾರ್ಯನಿರ್ವಹಿಸುತ್ತಿದ್ದರೂ ಸಹ, ನೈಜ ಸಮಯದಲ್ಲಿ ಜಾವಾಸ್ಕ್ರಿಪ್ಟ್ ದೋಷಗಳನ್ನು ಹಿಡಿಯಲಾಗುತ್ತದೆ.
ಅಂತಿಮವಾಗಿ, tab.evaluate() ನೇರವಾದ ಜಾವಾಸ್ಕ್ರಿಪ್ಟ್ ಹೇಳಿಕೆಯನ್ನು ಮೌಲ್ಯಮಾಪನ ಮಾಡಲು ಬಳಸಲಾಗುತ್ತದೆ, console.assert(false). ವಿಫಲವಾದ ಸಮರ್ಥನೆ ಅಥವಾ ಇತರ JavaScript ಸಮಸ್ಯೆಯನ್ನು ಸೆರೆಹಿಡಿಯಬೇಕಾದ ವೆಬ್ ಅಪ್ಲಿಕೇಶನ್ಗಳಲ್ಲಿ ಸಾಮಾನ್ಯ ಸನ್ನಿವೇಶವನ್ನು ಅನುಕರಿಸಲು, ಈ ಆಜ್ಞೆಯು ಉದ್ದೇಶಪೂರ್ವಕವಾಗಿ ದೋಷವನ್ನು ಉಂಟುಮಾಡುತ್ತದೆ. ಸಮಸ್ಯೆ ಉಂಟಾದಾಗ, ಡೆವಲಪರ್ಗಳು ಸ್ವಯಂಚಾಲಿತವಾಗಿ ಕಾರ್ಯಗತಗೊಳಿಸುವಿಕೆಯನ್ನು ವಿರಾಮಗೊಳಿಸಬಹುದು ಮತ್ತು ದೋಷ ಪತ್ತೆ ಮತ್ತು ಡೀಬಗರ್ ಅನ್ನು ಸಂಯೋಜಿಸುವ ಮೂಲಕ ಎಚ್ಚರಿಕೆಯನ್ನು ಪ್ರಚೋದಿಸಬಹುದು. ಕೊನೆಯದಾಗಿ, ಜಾವಾಸ್ಕ್ರಿಪ್ಟ್ ರನ್ ಆಗಲು ಸ್ಕ್ರಿಪ್ಟ್ ಸಾಕಷ್ಟು ಸಮಯ ಕಾಯುತ್ತದೆ ಮತ್ತು ಯಾವುದೇ ಸಮಸ್ಯೆಗಳ ಬಳಕೆಯನ್ನು ಕೊನೆಗೊಳಿಸುವ ಮೊದಲು ರೆಕಾರ್ಡ್ ಮಾಡಲು ಎಸ್ಟಿಡಿ::ಥ್ರೆಡ್::ಸ್ಲೀಪ್().
ಹೆಡ್ಲೆಸ್ ಕ್ರೋಮ್ನೊಂದಿಗೆ ರಸ್ಟ್ನಲ್ಲಿ ಜಾವಾಸ್ಕ್ರಿಪ್ಟ್ ದೋಷಗಳನ್ನು ಪತ್ತೆಹಚ್ಚಲಾಗುತ್ತಿದೆ
ಈ ವಿಧಾನವು ಜಾವಾಸ್ಕ್ರಿಪ್ಟ್ ಅನ್ನು ಕಾರ್ಯಗತಗೊಳಿಸಲು ಮತ್ತು ರಸ್ಟ್ ಅನ್ನು ಬಳಸಿಕೊಂಡು ಸಮಸ್ಯೆಗಳನ್ನು ಗುರುತಿಸಲು Chrome ನ ಡೀಬಗರ್ ಮತ್ತು ಲಾಗ್ ಪ್ರೋಟೋಕಾಲ್ಗಳನ್ನು ನಿಯಂತ್ರಿಸುತ್ತದೆ ತಲೆಯಿಲ್ಲದ_ಕ್ರೋಮ್ ಕ್ರೇಟ್.
use headless_chrome::{protocol::cdp::types::Event, Browser, LaunchOptions};
use std::{error::Error, sync::Arc};
fn main() -> Result<(), Box<dyn Error>> {
let browser = Browser::new(
LaunchOptions::default_builder()
.window_size(Some((2000, 2000)))
.build()
.expect("Could not find chrome-executable"),
)?;
let tab = browser.new_tab()?;
tab.enable_debugger().unwrap();
tab.enable_log().unwrap();
let _events = tab.add_event_listener(Arc::new(move |event: &Event| {
dbg!(event);
if let Event::DebuggerPaused(_paused_event) = event {
panic!("JavaScript error detected!");
}
}))?;
let _remote_object = tab.evaluate("console.assert(false);", true).unwrap();
std::thread::sleep(std::time::Duration::from_secs(1));
Ok(())
}
ಪರ್ಯಾಯ ವಿಧಾನ: ದೋಷ ಪತ್ತೆಗಾಗಿ ರಸ್ಟ್ನ ಪ್ಯಾನಿಕ್ ಹುಕ್ ಅನ್ನು ಬಳಸುವುದು
ಈ ಪರಿಹಾರವು ರಸ್ಟ್ನ ಪ್ಯಾನಿಕ್ ಹುಕ್ ಅನ್ನು ಬಳಸಿಕೊಂಡು ಜಾವಾಸ್ಕ್ರಿಪ್ಟ್ ಸಮಸ್ಯೆಗಳನ್ನು ಹಿಡಿಯಲು ಹೆಚ್ಚುವರಿ ವಿಧಾನವನ್ನು ತೋರಿಸುತ್ತದೆ, ಇದು ಪ್ಯಾನಿಕ್ ಸಂದೇಶವನ್ನು ಲಾಗ್ ಮಾಡುತ್ತದೆ ಮತ್ತು ಎಕ್ಸಿಕ್ಯೂಶನ್ ಫ್ಲೋ ಅನ್ನು ನಿರ್ವಹಿಸುತ್ತದೆ.
use headless_chrome::{Browser, LaunchOptions};
use std::panic;
fn main() -> Result<(), Box<dyn std::error::Error>> {
panic::set_hook(Box::new(|info| {
println!("Panic occurred: {:?}", info);
}));
let browser = Browser::new(LaunchOptions::default())?;
let tab = browser.new_tab()?;
tab.enable_log()?;
tab.evaluate("console.assert(false);", true)?;
std::thread::sleep(std::time::Duration::from_secs(1));
Ok(())
}
ರಸ್ಟ್ನಲ್ಲಿ ಜಾವಾಸ್ಕ್ರಿಪ್ಟ್ ದೋಷಗಳನ್ನು ಪತ್ತೆಹಚ್ಚಲು ಯುನಿಟ್ ಪರೀಕ್ಷೆಗಳೊಂದಿಗೆ ಪರಿಹಾರ
ಈ ಉದಾಹರಣೆಯು ರಸ್ಟ್ನೊಂದಿಗೆ ಹೆಡ್ಲೆಸ್ ಕ್ರೋಮ್ ಪರಿಸರದಲ್ಲಿ JavaScript ದೋಷಗಳನ್ನು ಪತ್ತೆಹಚ್ಚಬಹುದೆಂದು ಪರಿಶೀಲಿಸಲು ಘಟಕ ಪರೀಕ್ಷೆಗಳನ್ನು ಬಳಸುತ್ತದೆ. ದೋಷ-ನಿರ್ವಹಣೆಯ ಕಾರ್ಯವಿಧಾನದ ಸ್ಥಿತಿಸ್ಥಾಪಕತ್ವವನ್ನು ಪರೀಕ್ಷೆಯಿಂದ ಖಚಿತಪಡಿಸಿಕೊಳ್ಳಲಾಗುತ್ತದೆ.
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn test_js_error_detection() {
let browser = Browser::new(LaunchOptions::default()).unwrap();
let tab = browser.new_tab().unwrap();
tab.enable_log().unwrap();
let result = tab.evaluate("console.assert(false);", true);
assert!(result.is_err(), "Expected JavaScript error!");
}
}
ಈವೆಂಟ್ ಹ್ಯಾಂಡ್ಲಿಂಗ್ನೊಂದಿಗೆ ರಸ್ಟ್ನಲ್ಲಿ ಜಾವಾಸ್ಕ್ರಿಪ್ಟ್ ದೋಷ ಪತ್ತೆಯನ್ನು ಹೆಚ್ಚಿಸುವುದು
ಮೂಲ ಸ್ಕ್ರಿಪ್ಟ್ ಅನ್ನು ಬಳಸಿಕೊಂಡು ಜಾವಾಸ್ಕ್ರಿಪ್ಟ್ ದೋಷಗಳನ್ನು ಪತ್ತೆಹಚ್ಚಲು ಕೇಂದ್ರೀಕರಿಸುತ್ತದೆ ತಲೆಯಿಲ್ಲದ_ಕ್ರೋಮ್ ಪ್ಯಾಕೇಜ್, ದೋಷ-ನಿರ್ವಹಣೆ ದಕ್ಷತೆಯನ್ನು ಉತ್ತಮಗೊಳಿಸುವುದು ಸಹ ಅತ್ಯಗತ್ಯ. ಹೆಚ್ಚು ಸಂಕೀರ್ಣವಾದ ಈವೆಂಟ್ ಪ್ರಕಾರಗಳನ್ನು ಬಳಸುವುದು Runtime.exception ಥ್ರೋನ್ ಪ್ರಕ್ರಿಯೆಯನ್ನು ಸುಧಾರಿಸಲು ಒಂದು ವಿಧಾನವಾಗಿದೆ. JavaScript ವಿನಾಯಿತಿಗಳ ಕುರಿತು ಹೆಚ್ಚಿನ ನಿರ್ದಿಷ್ಟ ಮಾಹಿತಿಯನ್ನು ಈ ಪ್ರೋಟೋಕಾಲ್ ಈವೆಂಟ್ನಿಂದ ಪಡೆಯಬಹುದು, ಈ ವೈಫಲ್ಯಗಳನ್ನು ಹೇಗೆ ನಿರ್ವಹಿಸಲಾಗುತ್ತದೆ ಎಂಬುದರ ಕುರಿತು ನಿರ್ವಾಹಕರಿಗೆ ಹೆಚ್ಚು ನಿಖರವಾದ ನಿಯಂತ್ರಣವನ್ನು ನೀಡುತ್ತದೆ. ರನ್ಟೈಮ್ ವಿನಾಯಿತಿಗಳು ಅಥವಾ ತಪ್ಪಾದ ಕೋಡ್ನಿಂದಾಗಿ ದೋಷಗಳು ಉತ್ಪತ್ತಿಯಾಗುವ ಸಂದರ್ಭಗಳಲ್ಲಿ ಈವೆಂಟ್ ಕೇಳುಗರು ಸರಳವಾದ ಸಮರ್ಥನೆಯ ವೈಫಲ್ಯಕ್ಕಿಂತ ಹೆಚ್ಚಿನ ಮಾಹಿತಿಯನ್ನು ಒದಗಿಸಬಹುದು.
ಡೀಬಗ್ ಮಾಡುವ ಈವೆಂಟ್ಗಳಿಗೆ ಕಿವಿಗೊಡುವುದರ ಜೊತೆಗೆ ರಸ್ಟ್ನೊಂದಿಗೆ ತಪ್ಪುಗಳನ್ನು ಆಕರ್ಷಕವಾಗಿ ನಿರ್ವಹಿಸುವುದು ಬಹಳ ಮುಖ್ಯ. ಉದಾಹರಣೆಗೆ, ರಸ್ಟ್ ನ ಫಲಿತಾಂಶ ಮತ್ತು ಆಯ್ಕೆ ಬೆಸ್ಪೋಕ್ ದೋಷ ಪ್ರಕಾರಗಳನ್ನು ರಚಿಸಲು ಡೆವಲಪರ್ಗಳು ಪ್ರಕಾರಗಳನ್ನು ಬಳಸಬಹುದು. ಇದು ಜಾವಾಸ್ಕ್ರಿಪ್ಟ್ ವೈಫಲ್ಯಗಳಿಂದ ಸುಧಾರಿತ ದೋಷ ಪ್ರಸರಣ ಮತ್ತು ಮರುಪಡೆಯುವಿಕೆಯನ್ನು ಸಕ್ರಿಯಗೊಳಿಸುವ ಮೂಲಕ ನಿಮ್ಮ ರಸ್ಟ್ ಅಪ್ಲಿಕೇಶನ್ಗಳನ್ನು ಹೆಚ್ಚು ದೃಢವಾಗಿಸುತ್ತದೆ. ದೋಷಗಳನ್ನು ನಿಸ್ಸಂದಿಗ್ಧ ಸಂದೇಶಗಳೊಂದಿಗೆ ಕನ್ಸೋಲ್ನಲ್ಲಿ ಲಾಗ್ ಮಾಡುವ ಮೂಲಕ ಅವುಗಳನ್ನು ತ್ವರಿತವಾಗಿ ಗುರುತಿಸಬಹುದು, ವಿಶೇಷವಾಗಿ ಬ್ರೌಸರ್ನಿಂದ ದೃಶ್ಯ ಪ್ರತಿಕ್ರಿಯೆಯಿಲ್ಲದೆ ತಲೆಯಿಲ್ಲದ ವಾತಾವರಣದಲ್ಲಿ ಕೆಲಸ ಮಾಡುವಾಗ.
ಇದಲ್ಲದೆ, ಪರೀಕ್ಷೆಗಳನ್ನು ವಿವಿಧ ಪುಟಗಳಲ್ಲಿ ಅಥವಾ ಜಾವಾಸ್ಕ್ರಿಪ್ಟ್ ಸಂದರ್ಭಗಳಲ್ಲಿ ನಡೆಸಬಹುದು ತಲೆಯಿಲ್ಲದ_ಕ್ರೋಮ್ ಬಳಸಲಾಗುತ್ತದೆ. ವಿಭಿನ್ನ ಟ್ಯಾಬ್ಗಳು ಅಥವಾ ಸೆಷನ್ಗಳನ್ನು ನಿಯಂತ್ರಿಸುವ ಮೂಲಕ ನಿಮ್ಮ ಜಾವಾಸ್ಕ್ರಿಪ್ಟ್ ವಿವಿಧ ಆನ್ಲೈನ್ ಅಪ್ಲಿಕೇಶನ್ಗಳಲ್ಲಿ ಸರಿಯಾಗಿ ಕಾರ್ಯನಿರ್ವಹಿಸುತ್ತದೆ ಎಂದು ನೀವು ಖಚಿತಪಡಿಸಿಕೊಳ್ಳಬಹುದು. ಏಕೀಕರಣ ಪರೀಕ್ಷೆಯ ಸಂದರ್ಭಗಳಲ್ಲಿ ಜಾವಾಸ್ಕ್ರಿಪ್ಟ್ ಸಮಸ್ಯೆಗಳಿಗೆ ಏಕಕಾಲದಲ್ಲಿ ಹಲವಾರು ಅಂತಿಮ ಬಿಂದುಗಳನ್ನು ಪರೀಕ್ಷಿಸಲು ನಿಮಗೆ ಅನುಮತಿಸುವ ಮೂಲಕ ಪ್ರತ್ಯೇಕ ಸ್ಕ್ರಿಪ್ಟ್ಗಳನ್ನು ಡೀಬಗ್ ಮಾಡುವಾಗ ಇದು ಸಾಕಷ್ಟು ಸಮಯವನ್ನು ಉಳಿಸಬಹುದು.
ರಸ್ಟ್ನಲ್ಲಿ ಜಾವಾಸ್ಕ್ರಿಪ್ಟ್ ದೋಷಗಳನ್ನು ಪತ್ತೆಹಚ್ಚುವ ಬಗ್ಗೆ ಪದೇ ಪದೇ ಕೇಳಲಾಗುವ ಪ್ರಶ್ನೆಗಳು
- ನಾನು ಹೇಗೆ ಬಳಸಬಹುದು headless_chrome JavaScript ದೋಷಗಳನ್ನು ಕೇಳಲು ರಸ್ಟ್ನಲ್ಲಿ?
- ನೈಜ ಸಮಯದಲ್ಲಿ ಜಾವಾಸ್ಕ್ರಿಪ್ಟ್ ಸಮಸ್ಯೆಗಳನ್ನು ಗುರುತಿಸಲು, ನೀವು ಇದನ್ನು ಬಳಸಿಕೊಳ್ಳಬಹುದು tab.add_event_listener() ಮುಂತಾದ ಘಟನೆಗಳನ್ನು ಸಂಗ್ರಹಿಸುವ ವಿಧಾನ DebuggerPaused ಅಥವಾ Runtime.exceptionThrown.
- Rust ನಲ್ಲಿ JavaScript ವಿನಾಯಿತಿಗಳನ್ನು ನಿರ್ವಹಿಸಲು ಉತ್ತಮ ವಿಧಾನವಿದೆಯೇ?
- ಹೌದು, ರಸ್ಟ್ ಅನ್ನು ಬಳಸುವ ಮೂಲಕ ನಿಮ್ಮ ಪ್ರೋಗ್ರಾಂ ವೈಫಲ್ಯಗಳನ್ನು ಆಕರ್ಷಕವಾಗಿ ನಿಭಾಯಿಸುತ್ತದೆ ಎಂದು ನೀವು ಖಚಿತಪಡಿಸಿಕೊಳ್ಳಬಹುದು Result JavaScript ದೋಷಗಳನ್ನು ಸಂಗ್ರಹಿಸಲು ಮತ್ತು ರವಾನಿಸಲು ಟೈಪ್ ಮಾಡಿ.
- ಬಳಸುವುದರಿಂದ ಏನು ಪ್ರಯೋಜನ Runtime.exceptionThrown ಇತರ ಘಟನೆಗಳ ಮೇಲೆ?
- Runtime.exceptionThrown ಜಾವಾಸ್ಕ್ರಿಪ್ಟ್ ವಿನಾಯಿತಿಗಳ ಬಗ್ಗೆ ಹೆಚ್ಚು ಸಂಪೂರ್ಣವಾದ ವಿವರಗಳನ್ನು ನೀಡುತ್ತದೆ, ಇದು ರನ್ಟೈಮ್ ದೋಷಗಳ ಗುರುತಿಸುವಿಕೆ ಮತ್ತು ಉದ್ದೇಶಿತ ನಿರ್ವಹಣೆಯನ್ನು ಸುಗಮಗೊಳಿಸುತ್ತದೆ.
- ವಿಭಿನ್ನ ಜಾವಾಸ್ಕ್ರಿಪ್ಟ್ ದೋಷಗಳಿಗಾಗಿ ನಾನು ವಿವಿಧ ಟ್ಯಾಬ್ಗಳನ್ನು ಹೇಗೆ ಪರಿಶೀಲಿಸಬಹುದು?
- ಬಳಸುತ್ತಿದೆ browser.new_tab(), ನೀವು ಹಲವಾರು ಟ್ಯಾಬ್ಗಳನ್ನು ತೆರೆಯಬಹುದು ಮತ್ತು ವಿಭಿನ್ನ ವೆಬ್ ಪುಟಗಳಲ್ಲಿ ಜಾವಾಸ್ಕ್ರಿಪ್ಟ್ ಸಮಸ್ಯೆಗಳನ್ನು ಪರಿಶೀಲಿಸಲು ಪ್ರತಿ ಟ್ಯಾಬ್ಗೆ ವಿಭಿನ್ನ ಈವೆಂಟ್ ಕೇಳುಗರನ್ನು ಸೇರಿಸಬಹುದು.
- ಹೆಡ್ಲೆಸ್ ಬ್ರೌಸರ್ನಲ್ಲಿ ಜಾವಾಸ್ಕ್ರಿಪ್ಟ್ ದೋಷಗಳನ್ನು ಲಾಗ್ ಮಾಡುವುದು ಏಕೆ ಮುಖ್ಯ?
- ಬಳಸುತ್ತಿದೆ tab.enable_log() ಜಾವಾಸ್ಕ್ರಿಪ್ಟ್ ವೈಫಲ್ಯಗಳನ್ನು ಉತ್ತಮ ಡೀಬಗ್ ಮಾಡಲು ಕನ್ಸೋಲ್ನಲ್ಲಿ ಉಳಿಸಲಾಗಿದೆ ಎಂದು ಖಾತರಿಪಡಿಸುತ್ತದೆ, ಏಕೆಂದರೆ ಹೆಡ್ಲೆಸ್ ಬ್ರೌಸರ್ಗಳು ದೃಶ್ಯ ಇಂಟರ್ಫೇಸ್ ಅನ್ನು ಹೊಂದಿರುವುದಿಲ್ಲ.
ರಸ್ಟ್ನಲ್ಲಿ ಜಾವಾಸ್ಕ್ರಿಪ್ಟ್ ದೋಷಗಳನ್ನು ನಿರ್ವಹಿಸುವ ಅಂತಿಮ ಆಲೋಚನೆಗಳು
ಡೆವಲಪರ್ಗಳು ರಸ್ಟ್ಗಳನ್ನು ಬಳಸಿಕೊಂಡು ಜಾವಾಸ್ಕ್ರಿಪ್ಟ್ ಸಮಸ್ಯೆಗಳನ್ನು ಪರಿಣಾಮಕಾರಿಯಾಗಿ ಪತ್ತೆಹಚ್ಚುವ ಮತ್ತು ನಿರ್ವಹಿಸುವ ಸ್ವಯಂಚಾಲಿತ ಪ್ರಕ್ರಿಯೆಗಳನ್ನು ವಿನ್ಯಾಸಗೊಳಿಸಬಹುದು ತಲೆಯಿಲ್ಲದ_ಕ್ರೋಮ್ ಕ್ರೇಟ್. ವಿಶ್ವಾಸಾರ್ಹ ನೈಜ-ಸಮಯದ ದೋಷ ಪತ್ತೆಗಾಗಿ, ಡೀಬಗರ್ ಪ್ರೋಟೋಕಾಲ್ಗಳು ಮತ್ತು ಈವೆಂಟ್ ಕೇಳುಗರನ್ನು ಬಳಸಬಹುದು.
ವಿನಾಯಿತಿಗಳು ಸಂಭವಿಸಿದಂತೆ ಹಿಡಿಯುವ ಮೂಲಕ ಮತ್ತು ಅಭಿವೃದ್ಧಿ ಪ್ರಕ್ರಿಯೆಯನ್ನು ಸುಗಮಗೊಳಿಸುವ ಮೂಲಕ, ಈ ವಿಧಾನವು ಡೀಬಗ್ ಮಾಡುವ ಸಮಯವನ್ನು ಕಡಿಮೆ ಮಾಡಲು ಸಹಾಯ ಮಾಡುತ್ತದೆ. ಇದು ರಸ್ಟ್ನ ದೋಷ-ನಿರ್ವಹಣೆ ವೈಶಿಷ್ಟ್ಯಗಳೊಂದಿಗೆ ಸಂಯೋಜಿತವಾಗಿ ಡೆವಲಪರ್ಗಳು ತಮ್ಮ ಅಪ್ಲಿಕೇಶನ್ಗಳು ಹೆಡ್ಲೆಸ್ ಸಂದರ್ಭಗಳಲ್ಲಿ ಸರಿಯಾಗಿ ಕಾರ್ಯನಿರ್ವಹಿಸುವುದನ್ನು ಖಚಿತಪಡಿಸಿಕೊಳ್ಳಲು ಅನುಮತಿಸುತ್ತದೆ.
ರಸ್ಟ್ನಲ್ಲಿ ಜಾವಾಸ್ಕ್ರಿಪ್ಟ್ ದೋಷ ಪತ್ತೆಗಾಗಿ ಮೂಲಗಳು ಮತ್ತು ಉಲ್ಲೇಖಗಳು
- ಈ ಲೇಖನವು ವೆಬ್ ಆಟೊಮೇಷನ್ ಪರಿಕರಗಳು ಮತ್ತು ಹೆಡ್ಲೆಸ್ ಬ್ರೌಸರ್ ಕ್ರೇಟ್ಗಳಿಗಾಗಿ ಅಧಿಕೃತ ರಸ್ಟ್ ದಸ್ತಾವೇಜನ್ನು ಆಧರಿಸಿದೆ ತಲೆಯಿಲ್ಲದ_ಕ್ರೋಮ್, ನಲ್ಲಿ ಲಭ್ಯವಿದೆ ಹೆಡ್ಲೆಸ್ ಕ್ರೋಮ್ ಕ್ರೇಟ್ .
- ರಸ್ಟ್ ಸಮುದಾಯದ ವೇದಿಕೆಗಳಲ್ಲಿ ಕಂಡುಬರುವ ರಸ್ಟ್ನಲ್ಲಿನ ಜಾವಾಸ್ಕ್ರಿಪ್ಟ್ ದೋಷಗಳನ್ನು ನಿರ್ವಹಿಸುವ ಕುರಿತು ನೈಜ-ಪ್ರಪಂಚದ ಉದಾಹರಣೆಗಳು ಮತ್ತು ಚರ್ಚೆಗಳಿಂದ ಹೆಚ್ಚುವರಿ ಒಳನೋಟಗಳನ್ನು ಪಡೆಯಲಾಗಿದೆ: ರಸ್ಟ್ ಬಳಕೆದಾರರ ವೇದಿಕೆ .
- ಈ ಲೇಖನದಲ್ಲಿ ಬಳಸಲಾದ Chrome ನ ಡೀಬಗರ್ ಮತ್ತು ಲಾಗ್ ಪ್ರೋಟೋಕಾಲ್ಗಳ ವಿವರಗಳಿಗಾಗಿ, Chrome DevTools ದಸ್ತಾವೇಜನ್ನು ಉಲ್ಲೇಖಿಸಲಾಗಿದೆ: Chrome DevTools ಪ್ರೋಟೋಕಾಲ್ .